diff --git a/dlls/mshtml/protocol.c b/dlls/mshtml/protocol.c
index 6717500c333..05b4388ea8a 100644
--- a/dlls/mshtml/protocol.c
+++ b/dlls/mshtml/protocol.c
@@ -588,7 +588,7 @@ static HRESULT WINAPI ResProtocol_Start(IInternetProtocol *iface, LPCWSTR szUrl,
}
url_dll = url + sizeof(wszRes)/sizeof(wszRes[0]);
- if(!(url_file = strchrW(url_dll, '/'))) {
+ if(!(url_file = strrchrW(url_dll, '/'))) {
WARN("wrong url: %s\n", debugstr_w(url));
IInternetProtocolSink_ReportResult(pOIProtSink, MK_E_SYNTAX, 0, NULL);
mshtml_free(url);
@@ -605,10 +605,18 @@ static HRESULT WINAPI ResProtocol_Start(IInternetProtocol *iface, LPCWSTR szUrl,
src = FindResourceW(hdll, url_file, (LPCWSTR)RT_HTML);
if(!src) {
- WARN("Could not find resource\n");
- IInternetProtocolSink_ReportResult(pOIProtSink, HRESULT_FROM_WIN32(GetLastError()), 0, NULL);
- mshtml_free(url);
- return HRESULT_FROM_WIN32(GetLastError());
+ LPWSTR endpoint = NULL;
+ DWORD file_id = strtolW(url_file, &endpoint, 10);
+ if(endpoint == url_file+strlenW(url_file))
+ src = FindResourceW(hdll, (LPCWSTR)file_id, (LPCWSTR)RT_HTML);
+
+ if(!src) {
+ WARN("Could not find resource\n");
+ IInternetProtocolSink_ReportResult(pOIProtSink,
+ HRESULT_FROM_WIN32(GetLastError()), 0, NULL);
+ mshtml_free(url);
+ return HRESULT_FROM_WIN32(GetLastError());
+ }
}
if(This->data) {