SpringMVC框架整合(搭建框架——测试——上传图像) 2

简介: SpringMVC框架整合(搭建框架——测试——上传图像)

带参数传值的四种方法

向前端页面跳转需要Model(数据)和View(页面)

1.ModelAndView方式传值
@RequestMapping("/hello02")
    public ModelAndView hello02(ModelAndView modelAndView){
        modelAndView.setViewName("hello01.jsp");
        modelAndView.addObject("username","pp");
        return modelAndView;
    }
2.Model方式传值
@RequestMapping("/hello03")
    public String hello03(Model model){
        model.addAttribute("username","ppp");
        return "hello01.jsp";
    }
3.HttpServletRequest方式传值
@RequestMapping("/hello04")
    public String hello04(HttpServletRequest request){
        request.setAttribute("username","pppp");
        return "hello01.jsp";
    }
4.Map方式传值
@RequestMapping("/hello05")
    public String hello05(Map map){
        map.put("username","ppppp");
        return "hello01.jsp";
    }

其实四种传值方式本质上都是转发,比较常用的是Model方式。

重定项

重定项在SpringMVC中非常的简单就是在return后面添加redirect:

    @RequestMapping("/hello05")
    public String hello05(Map map){
        map.put("username","ppppp");
        return "redirect:/login.jsp";
    }

前端向后端传值

前端传值一般使用表单提交

前端传值页面

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<body>
<h2>Hello World!</h2>
<form action="/hello/hello03" method="post">
    用户名:<input type="text" name="username">
    密码:<input type="text" name="pwd">
    <br>
    <input type="submit" value="提交">
</form>
</body>
</html>

后端接收

可以直接把name值写在方法参数里面(不推荐使用

@RequestMapping("/hello03")
    public String hello03(String username,String pwd,Model model){
        System.out.println("用户名:"+username+"密码:"+pwd);
        model.addAttribute("username","ppp");
        return "hello01.jsp";
    }

也可以创建个实体类接收,前提实体类里要有这些属性(推荐使用

@RequestMapping("/hello03")
    public String hello03(User user,Model model){
        System.out.println("用户名:"+user.getUsername()+"密码:"+user.getPwd());
        model.addAttribute("username","ppp");
        return "hello01.jsp";
    }

网页报错跳转

应用场景,网页的404页面或者500页面

网页中只要有错误就会跳转到你设置的那个错误页面

这个是在本类里面的错误跳转,RuntimeException表示运行时的错误,可以改变

@ExceptionHandler(RuntimeException.class)
    public String error(Exception e){
        System.out.println(e.getMessage());
        return "error.jsp";
    }

写在SpringMVC配置文件表示这个项目中的错误都跳转,RuntimeException表示运行时的错误,可以改变

<!--有错误时跳转的页面-->
    <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
        <property name="exceptionMappings">
            <props>
                <prop key="java.lang.RuntimeException">error.jsp</prop>
            </props>
        </property>
    </bean>

Ajax方式

发起Ajax请求

发起Ajax请求只需要在方法上面添加@ResponseBody注解就可以实现

这样return返回的就不再是页面而是数据,前端发起Ajax请求就能获取到

    @RequestMapping("/hello06")
    @ResponseBody
    public String hello06(){
        User user=new User();
        user.setUsername("牛牛");
        user.setPwd("123");
        String result= JSON.toJSONString(user);
        return result;
    }

发起Ajax请求直接赋值

 @RequestMapping(value = "/hello07/{username}/{pwd}",produces = {"text/html;charset=utf-8"})
    @ResponseBody
    public String hello07(@PathVariable("username") String username,
                          @PathVariable("pwd") String pwd){
        return username+pwd;
    }

效果:

虽然这种方式很方便,但是不安全,用户也不会在这里直接输入,(目前不常用

上传图片

前端页面

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>上传页面</title>
</head>
<body>
    <form action="/hello/upload" method="post" enctype="multipart/form-data">
        <input type="text" name="username">
        <br>
        <input type="file" name="photo">
        <br>
        <input type="submit" value="提交">
    </form>
</body>
</html>

后端代码

@RequestMapping("/upload")
    public String upload(String username,MultipartFile photo,HttpServletRequest request){
        String fileType=photo.getOriginalFilename();//获取文件名
        int index=fileType.lastIndexOf(".");//获取文件后缀有几位
        fileType=fileType.substring(index);截取后缀
        String path=request.getSession().getServletContext().getRealPath("static"+ File.separator+"uploadfiles");//拼接地址
        long filename=System.currentTimeMillis();//获取当前时间时间戳
        File file=new File(path+"\\"+filename+fileType);//上传的地址
        System.out.println(path+"\\"+filename+fileType);//打印地址
        try {
            photo.transferTo(file);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return "上传成功";
    }

获取时间戳,将图片名称改为时间戳传入tomcat容器

输出:

可以通过此地址在网页里查询到刚刚上传的图片


拦截器

SpringMVC中写入拦截器

<mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/hello/**"/>
            <mvc:exclude-mapping path="/hello/hello04"/>
            <bean class="com.interceptor.LoginInterceptor"></bean>
        </mvc:interceptor>
    </mvc:interceptors>

解释:


<mvc:mapping path="/hello/**"/>拦截的地址

<mvc:exclude-mapping path="/hello/hello04"/>规定不拦截的地址

<bean class="com.interceptor.LoginInterceptor"></bean>调用拦截的类

拦截器类方法编写

package com.interceptor;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class LoginInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("preHandle");
        String username= request.getParameter("username");
        //判断是否有username
        if (null==username||"".equals(username)){
            response.sendRedirect("/index.jsp");
            return false;
        }
        return true;
    }
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("afterCompletion:页面没加载之前");
    }
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("afterCompletion:全部执行完毕后执行");
    }
}

应用场景:一般在登录页面

(完)

相关文章
|
1月前
|
人工智能 搜索推荐 数据管理
探索软件测试中的自动化测试框架选择与优化策略
本文深入探讨了在现代软件开发流程中,如何根据项目特性、团队技能和长期维护需求,精准选择合适的自动化测试框架。
115 8
|
16天前
|
存储 测试技术 API
pytest接口自动化测试框架搭建
通过上述步骤,我们成功搭建了一个基于 `pytest`的接口自动化测试框架。这个框架具备良好的扩展性和可维护性,能够高效地管理和执行API测试。通过封装HTTP请求逻辑、使用 `conftest.py`定义共享资源和前置条件,并利用 `pytest.ini`进行配置管理,可以大幅提高测试的自动化程度和执行效率。希望本文能为您的测试工作提供实用的指导和帮助。
78 15
|
25天前
|
数据采集 人工智能 自然语言处理
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
215 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
1月前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
73 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
1月前
|
安全 Ubuntu Linux
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
51 9
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
|
5天前
|
数据可视化 前端开发 测试技术
接口测试新选择:Postman替代方案全解析
在软件开发中,接口测试工具至关重要。Postman长期占据主导地位,但随着国产工具的崛起,越来越多开发者转向更适合中国市场的替代方案——Apifox。它不仅支持中英文切换、完全免费不限人数,还具备强大的可视化操作、自动生成文档和API调试功能,极大简化了开发流程。
|
5天前
|
存储 测试技术 数据库
接口测试工具攻略:轻松掌握测试技巧
在互联网快速发展的今天,软件系统的复杂性不断增加,接口测试工具成为确保系统稳定性的关键。它如同“翻译官”,模拟请求、解析响应、验证结果、测试性能并支持自动化测试,确保不同系统间信息传递的准确性和完整性。通过Apifox等工具,设计和执行测试用例更加便捷高效。接口测试是保障系统稳定运行的第一道防线。
|
5天前
|
Web App开发 JSON 测试技术
API测试工具集合:让接口测试更简单高效
在当今软件开发领域,接口测试工具如Postman、Apifox、Swagger等成为确保API正确性、性能和可靠性的关键。Postman全球闻名但高级功能需付费,Apifox则集成了API文档、调试、Mock与自动化测试,简化工作流并提高团队协作效率,特别适合国内用户。Swagger自动生成文档,YApi开源但功能逐渐落后,Insomnia界面简洁却缺乏团队协作支持,Paw仅限Mac系统。综合来看,Apifox是国内用户的理想选择,提供中文界面和免费高效的功能。
|
1月前
|
监控 JavaScript 测试技术
postman接口测试工具详解
Postman是一个功能强大且易于使用的API测试工具。通过详细的介绍和实际示例,本文展示了Postman在API测试中的各种应用。无论是简单的请求发送,还是复杂的自动化测试和持续集成,Postman都提供了丰富的功能来满足用户的需求。希望本文能帮助您更好地理解和使用Postman,提高API测试的效率和质量。
99 11
|
2月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
83 3

热门文章

最新文章