• gson哪些符号html转义,Gson-特殊字符的转义-disableHtmlEscaping()


    escapeHtmlChars属性

    GsonBuilder相关方法

    public GsonBuilder disableHtmlEscaping() {

    this.escapeHtmlChars = false;

    return this;

    }

    该属性默认为true,表示会将html中的字符例如< >这样的字符处理转义掉。设置为false后,就不会转义这些字符。直接看下面的例子更直观一些

    首先创建默认escapeHtmlChars为true的GsonBuilder

    private static GsonBuilder getGsonBuilder() {

    return new GsonBuilder().serializeNulls().enableComplexMapKeySerialization().serializeSpecialFloatingPointValues().setLenient();

    }

    测试代码:

    String content = "";

    test te= new test("colorcontent",content);

    //序列化

    String result = getGson().toJson(te);

    System.out.println(result);

    te = getGson().fromJson(result,te.getClass());

    //反序列化结果

    System.out.println(te.name+" "+te.score);

    序列化结果和反序列化结果分别为:

    {"name":"colorcontent","score":"u003cfont coloru003d"#FB4E44"u003e"}

    colorcontent

    我们看到序列化的结果中 若是设置为escapeHtmlChars为false,也就是不转义,那么会是什么呢?

    private static GsonBuilder getGsonBuilder() {

    return new GsonBuilder().disableHtmlEscaping().serializeNulls().enableComplexMapKeySerialization().serializeSpecialFloatingPointValues().setLenient();

    }

    测试结果为

    {"name":"colorcontent","score":""}

    colorcontent

    我们看到序列化的结果中左右尖括号并没有被转义,反序列化也是没有进行转义。所以该escapeHtmlChars影响序列化和反序列化是否转义html字符。

    什么时候要设置,什么时候不设置呢?这要看本身需求,后台和客户端打交道的时候,有时候字符串中会有=

     
     
  • 相关阅读:
    git 生成公钥与私钥
    Swagger PHP使用指南
    数据库需要支持emoji表情
    Lumen实现用户注册登录认证
    Laraver 框架资料
    php curl请求。header头中添加请求信息
    linux 下看所有用户 及所有组
    瀑布流下滑 发送ajax
    Linux系统中的wc
    Nginx 日志分析及性能排查
  • 原文地址:https://www.cnblogs.com/javalinux/p/15547309.html
Copyright © 2020-2023  润新知