VS调试异常问题解决(一)
一、无法在web服务器上启动调试,您没有调试web服务器进程的权限
具体:无法在web服务器上启动调试,您没有调试web服务器进程的权限,您需要以web服务器的用户账户身份运行,或者具有管理员权限。
现象:手动修改网站项目的启动端口号,调试报错
原因:从Windows NT 6.1开始,既Windows Vista版本开始,增强了用户控制,尤其是Windows 8。如果没有用系统优化软件做过用户控制,系统权限调整,即默认的情况下。
Visual Studio 必须是"以管理员身份运行",即鼠标右键"以管理员身份运行",不是指你当前登录的账户是不是Administrator的问题。否则当你的Visual Studio在F5启动调试的时候,就会出现以上错误:"无法在web服务器上启动调试,您没有调试web服务器进程的权限,您需要以web服务器的用户账户身份运行,或者具有管理员权限。"
解决办法:
桌面,鼠标移动到Visual Studio 2012 上方。右键--〉属性
单击--〉高级
在"用管理员身份运行(R)" 打勾,然后确定。OK,解决了。
或者每次右键"以管理员身份运行"。
二、设置网站项目(website)的默认启动端口
1.说明
在VS中 没有提供修改端口的地方,在网站的属性页中
不可修改
2.如果想要修改生产环境(IISExpress)的端口需要在解决方案源代码修改
使用记事本等打开.sln文件
手动修改启动地址。【不止一处】
三、web站点和控制台项目同时运行的方法
场景:本地修改了WCF的代码,随站点一起启动。现由一个控制台项目test 测试修改的功能,若想断点调试进本地WCF的代码,首先将本地站点(wcf)运行起来;然后,对控制台项目右键,调试-》启动新实例,就可以断点调试了。
四、VS断点调试问题
注:无法进入的断点是空心的,可以进入的断点是实心的。
- 当前不会命中断点,源代码与原始版本不同
因为调试时使用的是PDB(Program Database)文件,而当我们在类库中修改代码后,由于没有重新编译,会使用上次的PDB文件,这样就造成了原来的PDB和新的代码文件不匹配,自然调试时也就无法正确进入断点。
再有,有时断点会跳到其他的位置,是因为断点是定位在代码的行上的,而PDB文件中记录了代码的行数,但是PDB文件却没有更新,所以当我们强行将断点处的代码设置"允许源代码与原始版本不同"时,如果依旧使用上一次的PDB文件,自然断点的行数就定位到了上次记录的代码行数,所以断点就会往后跳了。
参考:VS调试时断点无法进入或命中的原因及解决方法(PDB引发的)
- 当前不会命中断点,还没有为该文档加载任何符号
参考:VS2017调试代码显示“当前无法命中断点,还没有为该文档加载任何符号”
注:在mvc中 视图cshtml中,如果 代码有错误,eg少了个using引用(而vs并没有提示),可能也是调试不进;还有Razor语法错误也是调试不进。
- 断点无效,断点未能绑定
检查项目属性,生成->优化编码,去掉勾选。
五、global.asax调试不进
问题:把断点打在global中的application_start()中,但VS不会在那个位置debug
因为application_start只运行一次,下一次再运行时,appDomain已经存在了所以还是跟不到断点,这时需要重启一下iis
六、端口80正在使用
1、问题:无法启动IIS Express Web服务器。来自IIS Express的输出:端口“80”正在使用
输入 netstat -aon|findstr "80" 回车,记下最后一位数字,即PID,这里是4。
继续输入tasklist|findstr "4",回车,查看是哪个进程或者程序占用了80端口,结果是:system
电脑需要重启。
2、若还没有解决问题,
Windows下80端口被pid为4的System进程占用解决方法
【使用端口映射查看命令netstat -ano
,发现80端口是被pid为4的System进程占用,按以前的经验:一是被IIS
占用;二是SQL Server Reporting Services
报表服务占用。
使用HTTP命令netsh http show servicestate
详细查看,会发现有80端口的信息,记下版本。
请求队列名称: 请求队列尚未命名。这个PID有问题
正常的是,请求队列名称: Clr4IntegratedAppPool{907947D4-6412-4B3E-BE5F-2847289D41F6}
于是结束掉这个PID=2556的服务,可以了
后来发现 ReportingServicesService是SQL Report的问题,直接将其禁用掉。
七、无法访问请求的页面,因为该页的相关配置数据无效
1、无法读取配置文件
初始配置web项目运行的时候,在属性中 用虚拟目录时,报以下错误
注意去看下项目目录下,.vs\config 中的配置路径等是否正确。
2、由于权限不足而无法读取配置文件
给文件夹加入IIS_IUSRS用户权限(注意要替换所有子目录权限也要选上)
八、VS中生成项目,报错: CS202 无法打开xxx.dll 进行写入,对路径xx.dll的访问被拒绝。
首先看下这个dll文件是否生成了(是否存在),有可能是不存在导致的。
若不存在,则可以看下是否有什么杀毒软件将这个文件清除了,导致每次生成后又删除,然后一直不存在,生成项目报错
九、VS中生成项目,报错: CS0006 未能找到元数据文件 xxx.dll
这个问题发生在—我在不同的解决方案中把一个项目搬来搬去,终于出现了传说的CSC : error CS0006。
编译的时候总是提示一个引用中不存在的项找不到。无论怎样删除项目,删除引用都没法通过生成。
解决方案:
打开csproj项目文件,找到包含出问题的引用项所在的 <ItemGroup>项,整个删除此项。
十、VS中生成项目,报错:模块 xxxx.dll的符号未加载
由于解决方案中的两个项目的命名空间名称都相同,导致项目中的调用不明确dll项目 不能加载。
因为 解决方案中有可能是既包括了源代码项目,又引用了Nuget包。可以将其中一个删除掉。
十一、发布报错:It was not possible to find any compatible framework version” with NET Core .app version 1.0.0
查看输出的内容:如下
“It was not possible to find any compatible framework version” with NET Core .app version 1.0.0
是说本地(C:\Program Files\dotnet\shared)缺少Microsoft.NETCore.App 1.0版本
图片中还有下载地址,进入后下载1.0 版本并安装,再重新发布即可。
网上也有解释
十二、windwos无法启动服务 错误1067:进程意外终止
C#编写的程序部署为服务,启动时报上面的错,
若程序没有捕获到相关的日志,则可以打开事件查看器 看下具体是什么错,再去修改。