OmniMarkupPreviewer的实时预览无法使用问题的解决

OmniMarkupPreviewer的实时预览无法使用

问题描述

Sublime下采用Package Control安装好OmniMarkupPreviewer之后,无法实现Markdown文件实时预览功能

解决过程

1.选择命令Preview Markup in Browser

在Markdown文件下右键选择命令Preview Markup in Browser 时,浏览器无法实时预览。
选择火狐浏览器打开的时候,如图

选择谷歌浏览器打开的时候,如图

2.查看日志信息

Ctrl+`打开控制台,查看日志信息,下面是我的日志信息。

OmniMarkupPreviewer: [INFO] Launching web browser for http://127.0.0.1:51004/view/29
UnicodeEncodeError('latin-1', '夏至', 0, 2, 'ordinal not in range(256)')
Traceback (most recent call last):
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1035, in communicate
    req.respond()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 831, in respond
    self.server.gateway(self).respond()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1868, in respond
    self.write(chunk)
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1934, in write
    self.req.send_headers()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 941, in send_headers
    (b"Server", self.server.server_name.encode('ISO-8859-1')))
UnicodeEncodeError: 'latin-1' codec can't encode characters in position 0-1: ordinal not in range(256)
UnicodeEncodeError('latin-1', '夏至', 0, 2, 'ordinal not in range(256)')
Traceback (most recent call last):
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1035, in communicate
    req.respond()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 831, in respond
    self.server.gateway(self).respond()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1868, in respond
    self.write(chunk)
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1934, in write
    self.req.send_headers()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 941, in send_headers
    (b"Server", self.server.server_name.encode('ISO-8859-1')))
UnicodeEncodeError: 'latin-1' codec can't encode characters in position 0-1: ordinal not in range(256)
UnicodeEncodeError('latin-1', '夏至', 0, 2, 'ordinal not in range(256)')
Traceback (most recent call last):
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1035, in communicate
    req.respond()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 831, in respond
    self.server.gateway(self).respond()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1868, in respond
    self.write(chunk)
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1934, in write
    self.req.send_headers()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 941, in send_headers
    (b"Server", self.server.server_name.encode('ISO-8859-1')))
UnicodeEncodeError: 'latin-1' codec can't encode characters in position 0-1: ordinal not in range(256)
UnicodeEncodeError('latin-1', '夏至', 0, 2, 'ordinal not in range(256)')
Traceback (most recent call last):
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1035, in communicate
    req.respond()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 831, in respond
    self.server.gateway(self).respond()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1868, in respond
    self.write(chunk)
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1934, in write
    self.req.send_headers()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 941, in send_headers
    (b"Server", self.server.server_name.encode('ISO-8859-1')))
UnicodeEncodeError: 'latin-1' codec can't encode characters in position 0-1: ordinal not in range(256)
UnicodeEncodeError('latin-1', '夏至', 0, 2, 'ordinal not in range(256)')
Traceback (most recent call last):
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1035, in communicate
    req.respond()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 831, in respond
    self.server.gateway(self).respond()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1868, in respond
    self.write(chunk)
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1934, in write
    self.req.send_headers()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 941, in send_headers
    (b"Server", self.server.server_name.encode('ISO-8859-1')))
UnicodeEncodeError: 'latin-1' codec can't encode characters in position 0-1: ordinal not in range(256)
UnicodeEncodeError('latin-1', '夏至', 0, 2, 'ordinal not in range(256)')
Traceback (most recent call last):
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1035, in communicate
    req.respond()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 831, in respond
    self.server.gateway(self).respond()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1868, in respond
    self.write(chunk)
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 1934, in write
    self.req.send_headers()
  File "C:\Users\xiazhi\AppData\Roaming\Sublime Text 3\Packages\OmniMarkupPreviewer\OmniMarkupLib\libs\cherrypy\wsgiserver\wsgiserver3.py", line 941, in send_headers
    (b"Server", self.server.server_name.encode('ISO-8859-1')))
UnicodeEncodeError: 'latin-1' codec can't encode characters in position 0-1: ordinal not in range(256)

Sublime的插件都是用Python写的,但是我并不会Python,但日志信息第一行可以看出
OmniMarkupPreviewer: [INFO] Launching web browser for http://127.0.0.1:51004/view/29
这是命令Preview Markup in Browser 开始执行,
下行开始就是错误信息,这里指出了是 UnicodeEncodeError 的错误。 UnicodeEncodeError('latin-1', '夏至', 0, 2, 'ordinal not in range(256)')

3.查找原因

我一开始以为是中文编码的问题,但是整篇文章无论是否有中文字符都是无法显示。但是日志信息中的第一行让我突然想起来我的计算机名字,没错就是下图

计算机名夏至,这样子应该可以对上了,感觉应该是无法发送数据到我本机上。

4.更改计算机名

更改下计算机名,转为英文,按要求重启

5.问题解决

最终结果,可以正常显示了。

结束语

感觉这应该是一个比较容易忽略的地方,虽然大多数人没有设置计算机名为中文的习惯,但是这个地方出了问题感觉还是难以发现的,记录下来和大家分享。

在Visual Studio 2022中,如果你正在编辑.cshtml文件,并希望实时预览它的效果,可以使用以下方法。 首先,你可以使用Asp.net来实现直接在浏览器中预览Word、Excel、PDF、Txt文件。这个方法可以帮助你在浏览器中直接预览.cshtml文件的效果。 另外,你还可以通过安装插件OmniMarkupPreviewer来实现实时预览.cshtml文件的效果。首先,你需要按下"Ctrl+Shift+P",然后搜索并安装OmniMarkupPreviewer插件。安装完成后,你可以打开.cshtml文件,然后在编辑器中按下"Ctrl+Shift+P"并搜索"OmniMarkupPreviewer"来启动预览。这样就可以实时查看.cshtml文件的效果。 此外,如果你希望同时预览多个.cshtml文件,你可以先选中要查看的多个文件,然后按下空格键。接着,按住"Command+Return"键就可以同时预览多个文件了。如果你想要全屏预览,可以在第一步中按住"Option+空格键",然后再进行第二步,就可以实现全屏预览了。 通过以上方法,你可以在Visual Studio 2022中实时预览.cshtml文件的效果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [vscode如何用浏览器预览运行html文件](https://blog.csdn.net/weixin_32652107/article/details/117804274)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值