首页
学习
活动
专区
圈层
工具
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在请求目标中找到无效字符。有效字符在RFC 7230和RFC 3986中定义

背景:   今天在使用Tomcat8部署完成项目做测试的时候,发现有的接口会报错400,后端提示在请求目标中找到无效字符。有效字符在RFC 7230和RFC 3986中定义 ?...原因分析:   是因为 日志显示请求地址中包含不合法字符,出现400错误   tomcat高版本严格按照RFC 3986规范解析地址。该规范只允许包含  a-zA-Z  0-9  -  _    ....  ~  以及所有保留字符  ! * ’ ( ) ; : @ & = + $ , / ?...# [ ]     但是项目在发起请求的参数中出现{},所以需要配置一下 解决方案:   在tomcat配置文件中做出以下配置,找到tomcat配置中的server.xml路径就在config文件夹下...作者:彼岸舞 时间:2020\11\04 内容关于:工作中用到的小技术 本文属于作者原创,未经允许,禁止转发

14.6K31

gbk和utf8的区别元尊_gb2312和utf8的区别

大家好,又见面了,我是你们的朋友全栈君。 我们这里将以最简单最容易理解的方式来描述GBK和UTF8的区别,以及它们分别是什么。...GBK编码:是指中国的中文字符,其它它包含了简体中文与繁体中文字符,另外还有一种字符“gb2312”,这种字符仅能存储简体中文字符。...UTF-8编码:它是一种全国家通过的一种编码,如果你的网站涉及到多个国家的语言,那么建议你选择UTF-8编码。 GBK和UTF8有什么区别?...UTF8编码格式很强大,支持所有国家的语言,正是因为它的强大,才会导致它占用的空间大小要比GBK大,对于网站打开速度而言,也是有一定影响的。...GBK编码格式,它的功能少,仅限于中文字符,当然它所占用的空间大小会随着它的功能而减少,打开网页的速度比较快。 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

1.3K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL字符集utf8和utf-8的关系

    个字节由8个二进制位组成 1个字节可表示256种不同的状态(256个不同符号) ASCII码规定了128个字符(英文字符和一些标点符号)的编码 Unicode国际化支持 世界上存在多种编码方式,同一个二进制数字被解释成了不同的符号...utf8 MySQL中实现了UTF-8编码的unicode 字符集 MySQL中utf8是utf8mb3的别名 utf8中,一个符号使用1~3个节点表示 对UTF-8支持不彻底,可采用utf8mb4字符集...utf8与utf8mb4的关系 都是实现了UTF-8编码的unicode 字符集 utf8仅支持基本多语言平面Basic Multilingual Plane (BMP) utf8mb4支持BMP之外的补充字符...(如emoji,emoji 是一种特殊的 Unicode 编码) utf8 一个字符最多使用3个字节存储,utf8mb4 一个字符最多使用4个字节存储 对于BMP字符,utf8和utf8mb4具有相同的编码...设置[mysql]和[client] 中的字符集 character-set-server 设置[mysqld] 进程的默认字符集 collation-server 设置[mysqld] 进程的默认校对规则

    89610

    utf8字符集下的比较规则

    前言: 在MySQL中,比较常用的字符集是utf8和utf8mb4。...这两个字符集是类似的,utf8是utf8mb3的别名,所以之后在MySQL中提到utf8就意味着使用1~3个字节来表示一个字符,如果大家有使用4字节编码一个字符的情况,比如存储一些emoji表情啥的,需要使用...其实每个字符集下对应着若干个比较规则(也可以翻译为排序规则或校对规则,英文是COLLATE),同一字符集下,使用不同的比较规则会影响字符字段的比较和排序。...每种字符集都有一种默认的比较规则,SHOW COLLATION的返回结果中的Default列的值为YES的就是该字符集的默认比较规则,比方说utf8字符集默认的比较规则就是utf8_general_ci...而utf8_general_ci和utf8_unicode_ci是不区分大小写的。 utf8_general_ci和utf8_unicode_ci对中、英文来说没有实质的差别。

    1.5K21

    utf8中文字符串的多模式匹配算法的优化

    效果 本节仅展示优化效果,对一些业务逻辑和背景未做解释,读者可直接跳至下一节。 上个月接触到了我组的一个关于在海量文本中匹配字符串业务。...原算法可以概括为“Trie Tree”和“Boyer-Moore 模式匹配算法”。Trie Tree是非常常见的组织字符串的数据结构。...一般地,命中第n次模式时,将会带来一次单模式哈希表的检查和 n-1 次双模式哈希表的检查。直到字符串扫描结束。进入处理多模式字符串的阶段。...很容易想到,如果以一个utf8字符为单位建Trie Tree比以Byte为单位建Trie Tree将获得更紧凑的内存布局,和更高效的cpu利用。既能提高速度又能节省内存。...扫描utf8字符串时,每次取一个Bigram,虽然跳节符跳字符步长仍然是一个utf8字符,但因为每次取出两个utf8字组成Bigram增加了上下文信息,匹配效率将大大增加,大量地减少了因为单个utf8字匹配到模式第一个

    3.9K30

    MySQL字符集你还在使用错误的utf8?

    所有在使用“utf8”的MySQL和MariaDB用户都应该改用“utf8mb4”,永远都不要再使用“utf8”。 MySQL的“utf8”不是真正的UTF-8。...同年9月,他们对MySQL源代码进行了一次调整:“UTF8现在最多只支持3个字节的序列”。 utfmb4字符集 支持BMP和补充字符。 每个多字节字符最多需要四个字节。...utf8mb4与utf8mb3字符集形成对比,后者仅支持BMP字符,每个字符最多使用三个字节: 对于BMP字符,utf8mb4和utf8mb3具有相同的存储特征:相同的代码值,相同的编码,相同的长度。...utf8mb4是utf8mb3的超集,因此对于诸如以下串联的操作,结果具有字符集utf8mb4和utf8mb4_col的排序规则: SELECT CONCAT(utf8mb3_col, utf8mb4_...UTF8或者其他UNICODE字符类型,这回造成大量的存储空间浪费。

    1.3K10

    关于 MySQL UTF8 编码下生僻字符插入失败假死问题的分析

    2、原因:此 utf8 非彼 utf8 那我们先来看看插入异常的中文和正常的中文有啥区别: 可以看到上面插入异常的文字占了 4 个字节,而我们插入正常的则只占了 3 个字节。...但是 utf8 字符编码不就是可变长,支持 1-4 字节的么?会和这个有关?...包括 Emoji 表情(Emoji 是一种特殊的 Unicode 编码,常见于 ios 和 android 手机上),和很多不常用的汉字,以及任何新增的 Unicode 字符等等。...3.2 强行过滤掉生僻字符串 从业务和技术的角度综合考虑,可以做个折中,将生僻字符串提前过滤掉,因为这类字符串本来就使用的很少,即使存进数据库了,展示、查询的时候也会多少有其它的问题,不如直接过滤掉,mysql...p=1149 [5] Mysql中4字节UTF8字符集问题 http://bbs.chinaunix.net/thread-3766853-1-1.html [6] MySQL,UTF-8和emoji

    3.7K90

    MySQL中的UTF8和UTF8mb4编码的详细区别

    原来mysql支持的 utf8 编码最大字符长度为 3 字节,如果遇到 4 字节的宽字符就会插入异常了。...也就是说,任何不在基本多文本平面的 Unicode字符,都无法使用 Mysql 的 utf8 字符集存储。...包括 Emoji 表情(Emoji 是一种特殊的 Unicode 编码,常见于 ios 和 android 手机上),和很多不常用的汉字,以及任何新增的 Unicode 字符等等。...最新的 UTF-8 规范只使用一到四个字节,最大能编码21位,正好能够表示所有的 17个 Unicode 平面。 Mysql 中的 utf8 为什么只支持持最长三个字节的 UTF-8字符呢?...当使用 utf8 字符集时,需要保留的长度就是 utf8 最长字符长度乘以字符串长度,所以这里理所当然的限制了 utf8 最大长度为 3,比如 CHAR(100) Mysql 会保留 300字节长度。

    6.3K30

    utf8和utf8mb4的区别

    好在utf8mb4是utf8的超集,除了将编码改为utf8mb4外不需要做其他转换。当然,为了节省空间,一般情况下使用utf8也就够了。...二、内容描述 那上面说了既然utf8能够存下大部分中文汉字,那为什么还要使用utf8mb4呢? 原来mysql支持的 utf8 编码最大字符长度为 3 字节,如果遇到 4 字节的宽字符就会插入异常了。...三个字节的 UTF-8 最大能编码的 Unicode 字符是 0xffff,也就是 Unicode 中的基本多文种平面(BMP)。...也就是说,任何不在基本多文本平面的 Unicode字符,都无法使用 Mysql 的 utf8 字符集存储。...包括 Emoji 表情(Emoji 是一种特殊的 Unicode 编码,常见于 ios 和 android 手机上),和很多不常用的汉字,以及任何新增的 Unicode 字符等等(utf8的缺点)。

    1.9K20

    行内元素的padding和margin是否无效

    、和其他元素都在一行上; 2、元素的高度、宽度及顶部和底部边距不可设置; 3、元素的宽度就是它包含的文字或图片的宽度,不可改变。...行内元素的padding、margin是否无效?...从上图可以看出,sapn标签的padding-top和padding-bottom在显示效果上是增加的,但是和上下两个div标签并没有间距,说明padding-top、padding-bottom设置是无效的...,margin-top和margin-bottom也是无效的, padding-left、padding-right、margin-left、margin-right都是有效的。...总结:行内标签(也叫内联标签)的padding和margin左右设置有效,而padding上下有显示效果,但是设置无效,margin上下也是设置无效,显示也无效。

    2.7K20

    NumberFormatException: 字符串转换为数字类型的无效转换完美解决方法

    NumberFormatException: 字符串转换为数字类型的无效转换完美解决方法 摘要 在Java编程中,NumberFormatException 是一种常见的异常,通常发生在尝试将无效字符串转换为数字类型时...今天,我将与大家分享这个异常的深入分析和完美解决方案,帮助你在编码过程中更加游刃有余。 正文 1....String invalidNumber = "12.34.56"; // 无效的数字格式 2.2 空字符串 试图将空字符串转换为数字类型时,也会抛出 NumberFormatException。...: " + e.getMessage()); 4.3 提供用户友好的提示 当用户输入无效格式时,提供清晰的错误提示,帮助用户更正输入。...希望本文的分析和示例能帮助你在编码过程中避免这一问题,让你的代码更加健壮。

    86110
    领券