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

进程pid4占用80端口的解决办法

电脑需要重启。

  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#编写的程序部署为服务,启动时报上面的错,

若程序没有捕获到相关的日志,则可以打开事件查看器 看下具体是什么错,再去修改。

 

posted @ 2018-03-16 19:43  peterYong  阅读(3175)  评论(0编辑  收藏  举报