初始SpringMVC(叁)

目录

8.介绍请求以及数据回显

9.解决乱码问题

10.什么是JSON 


8.介绍请求以及数据回显

    //前端传入参数最好用@RequestParam("参数名字") 来注解参数
    @GetMapping("/test02")
    public String test02(@RequestParam("name") String name,Model model){
        System.out.println("前端传来的数据name为:"+name);
        model.addAttribute("msg","请求成功");
        return "test";
    }

注意:如果参数被@RequestParam注解的话则前端必须要传入参数否则会报

同时我们也可以使用一个对象进行接受但是要注意对象中的字段名必须和前端传来的参数是一致的,而框架则帮我们把参数转换为了对象如:

    @GetMapping("/test03")
    public String test03(User user,Model model){
        System.out.println("前端传来的数据为:"+user);
        model.addAttribute("msg","请求成功");
        return "test";
    }

9.解决乱码问题

当前端给后台传递参数的时候可能会出现乱码问题(一般情况下GET请求不会出现乱码问题,但是POST会)这时可以使用过滤器进行编码直接的转换,如:

编写过滤器:

package com.xiao.filter;


import javax.servlet.*;
import java.io.IOException;

//编码转换的过滤器
public class EncodingFilter implements Filter {


    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        System.out.println("过滤器第一次开启");
        System.out.println(filterConfig.getFilterName());
        System.out.println(filterConfig.getServletContext());
        System.out.println(filterConfig.getInitParameterNames());
    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        servletRequest.setCharacterEncoding("utf-8");
        servletResponse.setCharacterEncoding("utf-8");
        filterChain.doFilter(servletRequest,servletResponse);
    }

    @Override
    public void destroy() {
        System.out.println("过滤器最后一次开启");
    }
}

过滤器配置:


<!-- 配置过滤器 -->
<filter>
    <filter-name>encodingFilter</filter-name>
    <filter-class>com.xiao.filter.EncodingFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>encodingFilter</filter-name>
    <url-pattern>/</url-pattern>
</filter-mapping>

但是如果时POST请求的话可能这种情况并不会生效就可以配置SpringMVC的编码转换器如:

    <!-- 配置过滤器 -->
    <filter>
        <filter-name>encoding</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>utf-8</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>encoding</filter-name>
        <url-pattern>/</url-pattern>
    </filter-mapping>

但是有些极端情况下也会出现问题,同时也对get支持不好则需要:

1.在Tomcat的server.xml中修改字符编码如:

    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" 
               URIEncoding="UTF-8"/>

2.使用通用的编码转换器类:

package com.kuang.filter;
 
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.Map;
 
/**
 * 解决get和post请求 全部乱码的过滤器
 */
public class GenericEncodingFilter implements Filter {
 
    @Override
    public void destroy() {
    }
 
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        //处理response的字符编码
        HttpServletResponse myResponse=(HttpServletResponse) response;
        myResponse.setContentType("text/html;charset=UTF-8");
 
        // 转型为与协议相关对象
        HttpServletRequest httpServletRequest = (HttpServletRequest) request;
        // 对request包装增强
        HttpServletRequest myrequest = new MyRequest(httpServletRequest);
        chain.doFilter(myrequest, response);
    }
 
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
    }
 
}
 
//自定义request对象,HttpServletRequest的包装类
class MyRequest extends HttpServletRequestWrapper {
 
    private HttpServletRequest request;
    //是否编码的标记
    private boolean hasEncode;
    //定义一个可以传入HttpServletRequest对象的构造函数,以便对其进行装饰
    public MyRequest(HttpServletRequest request) {
        super(request);// super必须写
        this.request = request;
    }
 
    // 对需要增强方法 进行覆盖
    @Override
    public Map getParameterMap() {
        // 先获得请求方式
        String method = request.getMethod();
        if (method.equalsIgnoreCase("post")) {
            // post请求
            try {
                // 处理post乱码
                request.setCharacterEncoding("utf-8");
                return request.getParameterMap();
            } catch (UnsupportedEncodingException e) {
                e.printStackTrace();
            }
        } else if (method.equalsIgnoreCase("get")) {
            // get请求
            Map<String, String[]> parameterMap = request.getParameterMap();
            if (!hasEncode) { // 确保get手动编码逻辑只运行一次
                for (String parameterName : parameterMap.keySet()) {
                    String[] values = parameterMap.get(parameterName);
                    if (values != null) {
                        for (int i = 0; i < values.length; i++) {
                            try {
                                // 处理get乱码
                                values[i] = new String(values[i]
                                        .getBytes("ISO-8859-1"), "utf-8");
                            } catch (UnsupportedEncodingException e) {
                                e.printStackTrace();
                            }
                        }
                    }
                }
                hasEncode = true;
            }
            return parameterMap;
        }
        return super.getParameterMap();
    }
 
    //取一个值
    @Override
    public String getParameter(String name) {
        Map<String, String[]> parameterMap = getParameterMap();
        String[] values = parameterMap.get(name);
        if (values == null) {
            return null;
        }
        return values[0]; // 取回参数的第一个值
    }
 
    //取所有值
    @Override
    public String[] getParameterValues(String name) {
        Map<String, String[]> parameterMap = getParameterMap();
        String[] values = parameterMap.get(name);
        return values;
    }
}

如果还是不行的话就需要注意一些配置的过滤器过滤的是否为"/"而不是"/* "!

注意点:

  • / 代表是只会匹配请求的而不会匹配后缀带.jsp/.html的
  • /* 是会匹配所有请求包括后缀带.jsp/.html

10.什么是JSON 

JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式。它基于 ECMAScript (欧洲计算机协会制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。

  • JSON是一种轻量级的数据交换格式
  • 采用完全独立于编程语言的文本格式来存储和表示数据
  • JSON向当于用字符串的形式来表示对象

 使用js的内置JSON方法可以互相转换对象如:

    let test={
        name:"小布",
        age:15
    }
    //将对象字符串化
    let s = JSON.stringify(test);
    //将字符串解析为对象
    let obj = JSON.parse(s);

而java转换对象需要dao'ru第三方jar包:

<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.13.2.2</version>
</dependency>

当传递JOSN的时候都需要在Spring配置文件中配置防止乱码问题:

    <!-- 配置JSON乱码问题 -->
    <mvc:annotation-driven>
        <mvc:message-converters register-defaults="true">
            <bean class="org.springframework.http.converter.StringHttpMessageConverter">
                <constructor-arg value="UTF-8"/>
            </bean>
            <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
                <property name="objectMapper">
                    <bean class="org.springframework.http.converter.json.Jackson2ObjectMapperFactoryBean">
                        <property name="failOnEmptyBeans" value="false"/>
                    </bean>
                </property>
            </bean>
        </mvc:message-converters>
    </mvc:annotation-driven>

使用JOSN传递数据:

    @GetMapping("/test01")
    @ResponseBody       //不会经过视图解析器,直接返回字符串数据
    public String test01() throws JsonProcessingException {
        ObjectMapper objectMapper = new ObjectMapper();
        User user = new User(1,"小布",16);
        //将对象转换为字符串
        String s = objectMapper.writeValueAsString(user);
        System.out.println(s);
        //将字符串转换为对象
        User user1 = objectMapper.readValue(s, User.class);
        return s;
    }

结果:

  • @RestController 表示被该注释的控制器下的请求会自动跳过视图解析器
  • @ResponseBody 表示被该注释的请求会自动跳过视图解析器

FastJSON 

fastjson也是使对象转换为json字符串,Maven依赖:

        <!-- fastjson转换 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>2.0.2.graal</version>
        </dependency>

测试:

    @GetMapping("/test02")
    @ResponseBody
    public String test02() {
        User user = new User(1,"小布",16);
        //将对象转换为字符串
        String s = JSON.toJSONString(user);
        //将字符串解析为对象
        User user1 = JSON.parseObject(s, User.class);
        
        return s;
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

123小步

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值