@ResponseBody返回JSON数据,360安全浏览器弹出下载页面

本文档记录了一个关于JSON数据在360浏览器中不正常显示,而被当作文件下载的问题。当项目部署到阿里云服务器并使用360浏览器访问时,JSON响应被当作文件下载,而在Chrome浏览器中却能正常显示。通过引入fastjson库并修改Controller代码以设置响应头,问题得到了解决。现在无论在本地还是阿里云服务器上,360浏览器和Chrome浏览器都能正确显示JSON数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题重现

Controller中使用@ResponseBody返回JSON数据。

@Controller
public class StudentController {

    @Autowired
    private StudentService studentService;

    @RequestMapping(path = "/", method = RequestMethod.GET)
    @ResponseBody
    public List<Student> selectStudents() {
        return studentService.selectStudents();
    }
}

下图:本机运行项目,用360安全浏览器访问,没有问题。
在这里插入图片描述
下图:把项目部署到阿里云服务器上,用360安全浏览器访问,不会显示想要展示的JSON字符串,而是会把字符串存到后缀为.json的文件里,下载下来。
在这里插入图片描述
下图:把项目部署到阿里云服务器上,用chrome浏览器访问,没有问题。
在这里插入图片描述

解决方法

pom.xml 里加上:

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.58</version>
        </dependency>

修改Controller代码为:

@Controller
public class StudentController {

    @Autowired
    private StudentService studentService;

    @RequestMapping(path = "/", method = RequestMethod.GET)
    //@ResponseBody
    public void selectStudents(HttpServletResponse response) {
        //return studentService.selectStudents();
        response.setContentType("text/html;charset=utf-8");
        try (
                PrintWriter writer = response.getWriter();
        ) {
            writer.write(JSON.toJSONString(studentService.selectStudents()));
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

成功解决

下图:此时本地可以访问。
在这里插入图片描述
下图:把项目部署到阿里云服务器上,用360安全浏览器访问,可以显示想要展示的JSON字符串。
在这里插入图片描述

下图:把项目部署到阿里云服务器上,用chrome浏览器访问,没有问题。
在这里插入图片描述

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值