2、其次在“推荐的程序”和“其他程序”中找有没有VCMicrosoft(R)DeveloperStudio,如果没找到,就用“浏览”去找VC的EXE文件。
3、然后选定工具后,一定记住在下面设成ON:始终使用选择的程序打开这种文件。
4、最后点击确定即可。
当电脑提示由于找不到VCRUNTIME140_1.dll软件无法运行打开,我们需要怎么修复呢?VCRUNTIME140_1.dll文件是Windows系统中的重要组件,缺失很多软件跟游戏都无法打开运行,小编今天就把修复方法分享给大家;修复方法如下:
首先是打开电脑浏览器后在顶部输入:dll修复工具.site【按下键盘的回车键打开】,搜索对应的修复程序后下载;
下载好了以后还是压缩文件,鼠标移到文件上方,右键选择解压;
解压好了以后,鼠标移到修复程序文件上方,右键选择以管理员身份运行打开;
进入修复程序以后,点击下方的安装按钮,开始安装修复电脑缺失损坏的dll文件;
等待修复完成以后,点击完成按钮退出;
安装修复完成以后,电脑桌面上是没有文件跟图标的,主要修复安装的文件是在电脑C盘的Windows文件中:一般32位系统的文件是在C:\Windows\System32文件夹中,64位系统的文件是在C:\Windows\SysWOW64;
修复完成以后,可以打开一下软件或者游戏,如果还是提示dll文件丢失,可以重启一下电脑,就可以正常打开了;
可以修复Windows7-win10-win11系统丢失dll文件问题;
分类: 电脑/网络 >>软件 >>其他软件问题描述:
估计与IE的配置文件或者注册表某些特定键值有关,谢~
解析:
在具体使用的时候需要增加头文件#include <wini.h>和库 WININET.LIB
程序代码
------------------------------------------------------------------
@ProxyType 代理类型,如HTTP,SOCKS,FTP...
@ProxyAddr 返回代理服务器的地址
@ProxyPort 返回代理服务器的端口
返回值
0: 无错误
-1: 查询IE的代理失败
-2: 无此类型的代理
-3: 其他错误
-4: 无代理设置信息
int GetIEProxy(CString ProxyType,CString &ProxyAddr,int &ProxyPort)
{
unsigned long nSize = 4096
char szBuf[4096] = { 0 }
Read IE settings
INTERNET_PROXY_INFO* pInfo = (INTERNET_PROXY_INFO*)szBuf
if(!InterQueryOption(NULL, INTERNET_OPTION_PROXY, pInfo, &nSize))
{
return -1查询IE的代理失败!
}
CString strTmp (pInfo->lpszProxy)
if (strTmp.IsEmpty()) return -4无代理设置信息
int nStart=0,nPos,nCurLen
CString strProxyType = ProxyType
strProxyType += "="
此时的结构如下
socks=192.168.1.100:3080 =192.168.1.100:808 =192.168.1.100:808 gopher=192.168.1.100:808 ftp=192.168.1.100:808
strTmp.MakeUpper()转化为大写
strProxyType.MakeUpper()
nCurLen = strTmp.GetLength()
nPos = strTmp.Find(strProxyType.GetBuffer(0),nStart)
if (nPos>=0)
{
strTmp = strTmp.Right(nCurLen - nPos)
strTmp.TrimLeft()
nCurLen = strTmp.GetLength()
到此结构如下
HTTP=192.168.1.100:808 gopher=192.168.1.100:808 ftp=192.168.1.100:808
获取单独的协议部分
nPos = strTmp.Find(" ",nStart)
if (nPos>=0)
{
strTmp = strTmp.Left(nPos)
strTmp.TrimRight()
nCurLen = strTmp.GetLength()
到此结构如下
HTTP=192.168.1.100:808
取掉协议名称部分
strTmp = strTmp.Right(nCurLen-strProxyType.GetLength())
nCurLen = strTmp.GetLength()
到此结构如下
192.168.1.100:808
nPos = strTmp.Find(":",nStart)
if (nPos>0)必须要大于0
{
ProxyAddr = strTmp.Left(nPos)
strTmp = strTmp.Right(nCurLen-nPos-1)
strTmp.TrimLeft()
strTmp.TrimRight()
ProxyPort = atoi(strTmp)
return 0
}
else
{
return -3
}
}
else
{
return -3
}
}
else
{
return -2无此类型的代理
}
}
你这个是旧的方法(IE4 and earlier)了,从IE5开始,最好使用
INTERNET_OPTION_PER_CONNECTION_OPTION来Invoke InterQueryOption,详细内容可以参考MS Q226473
如何编程动态改变IE的代理服务器设置, 并且使之马上生效!
用到的关键函数是wini库里面的InterSetOption. msdn里面有对它详细的介绍, 可以自己去看看. 当把参数dwOption设置为INTERNET_OPTION_SETTINGS_CHANGED的时候. 他就会促使IE在下一次打开网页的时候重新到注册表里面去取代理的设置信息. 所以我们就可以先将注册表里面的代理信息更改掉, 然后调用InterSetOption函数, 从而达到使自己想要的代理设置马上生效的目的.
下面的函数可以实现改变IE的代理服务器设置的目的. 里面加了少许的注释以帮助大家理解.
BOOL SetHttpProxy(CString ip, UINT port)
{
CString l_just
l_just.Format("=%s:%d", ip.LockBuffer(), port)
下面的代码将注册表项HKEY_CURRENT_USER\\Sofare\\Microsoft\\Windows\\CurrentVersion\\Inter Settings\\ProxyServer
的内容取出来
HKEY hKeyIn = HKEY_CURRENT_USER, hKeyOut
if( ERROR_SUCCESS != RegOpenKeyEx(hKeyIn, "Sofare\\Microsoft\\Windows\\CurrentVersion\\Inter Settings", 0, KEY_CREATE_LINK | KEY_WRITE | KEY_READ | KEY_NOTIFY, &hKeyOut))
{
return FALSE
}
ULONG regsize = 0
if(ERROR_SUCCESS != RegQueryValueEx(hKeyOut, "ProxyServer", NULL, NULL, NULL, &regsize))
{
return FALSE
}
LPBYTE pValue = new BYTE[regsize]
memset(pValue, 0x00, regsize)
if(ERROR_SUCCESS != RegQueryValueEx(hKeyOut, "ProxyServer", NULL, NULL, pValue, &regsize))
{
return FALSE
}
CString oldproxy((char *)pValue)
delete [] pValue
pValue = NULL
从注册表中读出来的数据格式为:=111.111.111.111:80ftp=222.222.222.222:21......,
如果你只想改变的代理的话, 就只要把其中的111.111.111.111:80换成你想要的代理就行了,
类似的你可以改变其他的代理.
下面的代码就替换代理成为参数所指定的代理.
int pos = 0
如果没有字符串中没有找到"="说明用户没有设置代理,这时候直接加在最前面.
if(-1 == (pos = oldproxy.Find("=")))
{
pos = 0
}
int pos1 = 0
if(-1 == (pos1 = oldproxy.Find("", pos)))
{
pos1 = oldproxy.GetLength()
}
oldproxy.Delete(pos, pos1 - pos)
oldproxy.Insert(pos, l_just)
if(ERROR_SUCCESS != RegSetValueEx(hKeyOut, "ProxyServer", 0, REG_SZ, (const unsigned char *)oldproxy.LockBuffer(), oldproxy.GetLength() + 1))
{
return FALSE
}
RegCloseKey(hKeyOut)
使设置生效
if(!InterSetOption(NULL, INTERNET_OPTION_SETTINGS_CHANGED, NULL, 0))
{
return FALSE
}
return TRUE
}
最后在使用此函数的时候不要忘记包含头文件 #include <wini.h>和lib: wini.lib
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)