问题:使用不对的http协议发送请求

情景描述

  • 使用nginx反向代理服务器
  • 服务器支持https协议
  • 发送请求的时候将url写成了http开头
  • 发现服务器返回错误org.xml.sax.SAXParseException: The element type "hr" must be terminated by the matching end-tag "</hr>"

矛盾点

  • 单纯分析错误发现是由于
    标签没有闭合造成的异常,那么正常思路就是去找找服务器中哪里发送了这个html。所以我到服务器全局搜索
    这个标签都没有找到。完全没了解决思路。
  • 我们在编写html文件的时候明明
    是可以没有</hr>的,为什么在这里会抛出异常?

是什么SAXParseException异常?

  • SAX知识补充:

    • SAX(simple api for xml):是一种XML解析的替代方法
    • SAX相比于DOM,是一种速度更快,更有效的解析XML文件的方式
    • 原理:它逐行扫描文档,一边扫描一边解析,可以在解析文档的任意时刻停止解析。

    总结:由上可以知道SAX专门用来解析XML文件,并且边扫描边解析。服务器解析xml的时候,解析到


    然后发现有问题然后抛出异常。

  • get到的非技术相关:

    • 看到一个异常被抛出:
      • 为什么抛出异常(其实就是异常message)
      • 这是什么异常(可以帮助你更多的了解上下文)
      • 什么抛出的(上一个问题基本可以帮助你定位)
    • 但是其实光看message有时候是可以定位错误的
  • 这个时候可以解释矛盾点二:

    • 首先在html中<hr>可以不闭合
    • 但是我们这是xml文件

XML和HTML的区别又是啥

    • XML:可扩展标记语言
    • HTML: 超文本标记语言
    • 相同点:
      • 都是标记语言,用于数据的保存和传输
    • 不同
      • 虽然都是跨平台标记语言:
        • xml:很多的编程语言都可以读取其中数据(由于很多语言都内置了xml解析器)
        • html:不同浏览器都可以解析html语言,并且将他显示出来。
      • 服务对象:
        • xml:主要用于数据存储,重点在于数据能够被读取识别,因此是数据传输的一种很好的格式。但是不用于显示,浏览器无法识别。
        • html:相当于一种标准,定义了一堆标签重点在于显示,不在于数据。
      • 自定义标签:
        • xml:可以自定义标签扩展性好
        • html:由于是一种w3c标准。为了任何浏览器都可以识别标签,绝对不可以自定义,因此扩展性差。
      • 语法
        • xml:严格要求嵌套、配对,并遵循DTD的树形结构;区分大小写;属性值必须分装在引号中;所有的属性都必须带有相应的值;空白部分不会被解析器自动删除;xml比html 语法要求更严格
        • html:不要求标记的嵌套、配对等;不区分大小写引号是可用可不用的;可以拥有不带值的属性名;过滤掉空格;
  • -----> 结论:其实最大的差距在于用途不一致:html主要的用途就是在浏览器显示focus在如何显示出数据。而xml主要在于数据的传输,focus在如何更加方便各种语言阅读数据。

  • -----> 和问题相关的结论:xml的语法要求严格因此对于html中可以不封闭的
    标签在xml中会报错。response中HEADER的accept可以是XML也可以是HTML。因此可以大胆猜测:服务器以为自己(约定)收到的是XML的response,因此使用xml解析器去解析,但是实际发送过来的却是html。因此gateway的response出错

  • ----> 类比:其实这个问题类似于我曾经在浏览器中看到过不能找到< 这样的错误。就是由于HEADER中的Accept告诉浏览器发送过来的是一个html文件,但是实际发过来的可能是js文件因此一定不是<开头

到底是哪里来的html里面带了

  • 首先判断这肯定是错误情况出现的,所以可以看看错误的请求能得到什么response。这里我还是求助了老师,发现当我请求了一个错误的路径,nginx会返回404not found其中的response是
 <html>
    <head><title>404 Not Found</title></head>
    <body bgcolor="white">
    <center><h1>404 Not Found</h1></center>
<hr>
<center>nginx/1.10.3</center>
</body>
</html>`
恰巧有hr。
  • 因此错误可以这样理解,gateway服务器请求某个错误的url,nginx由于没有资源返回了404 html,但是gateway本来应该约定收到xml,因此出错。

使用错误的协议发请求

  • 例子:url使用http发送请求到https服务器一定会导致请求failed而且什么内容都拿不到。
  • 如何避免:看清楚你服务器启动时候的log信息:他会给你打印:
    • 端口号
    • 协议类型

反思

  • 当看到服务器抛出异常没有一种冷静逻辑的分析思路,思维发散。试一下试不出来就换方法。简单的说还是在碰运气。

action

  • 以后看到问题,需要先构思解决思路。告诉自己首先应该干什么如果。。然后怎么样。。必须有思路,并且问题解决完毕必须说明为什么出现这个问题。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,417评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,921评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,850评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,945评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,069评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,188评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,239评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,994评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,409评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,735评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,898评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,578评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,205评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,916评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,156评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,722评论 2 363
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,781评论 2 351

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,644评论 18 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,605评论 18 399
  • 一. Java基础部分.................................................
    wy_sure阅读 3,807评论 0 11
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,936评论 6 13
  • 所有的营销都是基于产品的营销。 很多人看到这句话的第一反应是:产品做好了销售就自然起来了,玩那么多花样不如把产品打...
    谌基平阅读 628评论 0 0