麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

SpringMVC 的 Controller 返回各種視圖的處理方式

2019-11-15 00:43:36
字體:
來源:轉載
供稿:網友
SPRingMVC 的 Controller 返回各種視圖的處理方式

SpringMVC 的 Controller 可以返回各種各樣的視圖。比如 jsp, JSON, Velocity, FreeMarker, xml, PDF, Excel, 還有Html字符流 等等。那它們該如何的進行處理的呢?這里就涉及到 各種視圖(View)對應的各種視圖解析器(ViewResolver). 基本上上面說的每一種視圖就對應用一種視圖解析器來處理。基本上各種視圖解析器大致上可以分為兩類:一是基于URL的視圖解析器;一種是其它解析器;所謂的UrlBasedViewResolver,就是將返回值作為最終視圖的url的一部分,然后和相關配置組合起來,就是最終的視圖地址url. 我們看下UrlBasedViewResolver的解析器有哪些:

1. 返回JSP

返回JSP是最簡單的,JSP視圖的視圖解析器為 InternalResourceViewResolver,也是一個UrlBasedViewResolver解析器。其對應的解析器的配置一般如下:

<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">    <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>    <property name="prefix" value="/WEB-INF/jsp/"/>    <property name="suffix" value=".jsp"/></bean>

使用該例子,我們好好理解下什么是 “基于URL” 的視圖解析器,比如我們的 Controller 中最后的返回的處理代碼為: return "index"; 那么“基于URL” 的視圖解析器就會將返回值 “index” 作為最后視圖的URL的一部分,然后結合上面的配置 <property name="prefix" value="/WEB-INF/jsp/"/> 和 <property name="suffix" value=".jsp"/>,最后得到最終的URL: "/WEB-INF/jsp/" + "index" + ".jsp" == "/WEB-INF/jsp/index.jsp"

這就是所謂的 “基于URL” 的視圖解析器的工作方式。

2. 返回 HTML 頁面

我們知道在Servlet中,我們是可以直接在其中打印輸出HTML字符流到最終頁面,比如下面的代碼來自阿里巴巴的支付寶的接入示例中的代碼:

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {        request.setCharacterEncoding("utf-8");        response.setCharacterEncoding("utf-8");                        // ... ...                //建立請求        String sHtmlText = Al
    /**     * 建立請求,以表單HTML形式構造(默認)     * @param sParaTemp 請求參數數組     * @param strMethod 提交方式。兩個值可選:post、get     * @param strButtonName 確認按鈕顯示文字     * @return 提交表單HTML文本     */    public static String buildRequest(Map<String, String> sParaTemp, String strMethod, String strButtonName) {        //待請求參數數組        Map<String, String> sPara = buildRequestPara(sParaTemp);        List<String> keys = new ArrayList<String>(sPara.keySet());        StringBuffer sbHtml = new StringBuffer();        sbHtml.append("<!doctype html><html><head><meta http-equiv=/"Content-Type/" content=/"text/html; charset=UTF-8/">");        sbHtml.append("<title>支付寶即時到賬交易接口</title></head><body>");        sbHtml.append("<form id=/"alipaysubmit/" name=/"alipaysubmit/" action=/"" + ALIPAY_GATEWAY_NEW                      + "_input_charset=" + AlipayConfig.input_charset + "/" method=/"" + strMethod                      + "/">");        for (int i = 0; i < keys.size(); i++) {            String name = (String) keys.get(i);            String value = (String) sPara.get(name);            sbHtml.append("<input type=/"hidden/" name=/"" + name + "/" value=/"" + value + "/"/>");        }        //submit按鈕控件請不要含有name屬性        sbHtml.append("<input type=/"submit/" value=/"" + strButtonName + "/" style=/"display:none;/"></form>");        sbHtml.append("<script>document.forms['alipaysubmit'].submit();</script>");        sbHtml.append("</body></html>");        return sbHtml.toString();    }

很顯然,Servlet直接將HTML的字符流輸出到了瀏覽器端,那么在SpringMVC中該如何做呢?其實在SpringMVC中我們也是可以如下實現的:

    @RequestMapping(value="/getPage")    public void writeSubmitHtml(Reader reader, Writer writer, Httpsession session) throws IOException {        User user = (User) session.getAttribute(ConstantConfig.LONGIN_USER);        StringBuffer sbHtml = new StringBuffer();        sbHtml.append("<!doctype html><html><head><meta http-equiv=/"Content-Type/" content=/"text/html; charset=UTF-8/">");        sbHtml.append("<title>支付寶即時到賬交易接口</title></head><body>"+ user.getNo() +"</body></html>");        writer.write(sbHtml.toString());      }

我們看到我們直接使用了參數 Writer writer,返回值為 void, 其實參數 Writer writer 也可以換成 PrintWriter writer; 直接寫出HTML的字符流

我們也知道在Servlet中,我們是可以直接forward或者redirecit到html頁面,所以我們也可以如下在springmvc中返回到html頁面:

    @RequestMapping(value="/htmlView")    public void htmlView(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{        // ...        request.getRequestDispatcher("index.html").forward(request, response);     //response.sendRedirect("http://www.baidu.com");    }

這里,我們體會到了:springmvc他是建立在servlet之上的,所以在servlet中能夠做到的,同樣在springmvc一樣有效

3. 返回JSON格式

返回JSON格式在SpringMVC中有多種處理方式,一種是使用SpirngMVC自帶的 MappingJackson2JsonView 來處理,一種是自己寫代碼將返回值JSON格式化,然后直接用PrintWrite類型的對象寫出就行了。

1)直接用PrintWrite類型的對象寫出JSON格式

    @RequiresRoles(value={"student"})    @RequestMapping(value="/queryScoreForStudent")    public void queryScoreForStudent(ScoreQueryParam param, HttpSession sesion, PrintWriter printWriter){        Student student = (Student)sesion.getAttribute(ConstantConfig.LONGIN_STUDENT);        param.setStudentId(student.getId());        PageBean<StudentScore> scoreList = this.studentCourseService.queryScoreForStudent(param);        if(scoreList != null && scoreList.getSize() > 0){            Map<String, Object> map = new HashMap<>();            map.put("result", "ok");            map.put("data", scoreList);            printWriter.write(JSON.toJSONString(map));        }    }

如上代碼所示,我們在方法中加入了 PrintWriter printWriter 參數,最后的返回結果使用了fastjson庫來格式化最后的返回的對象map. 然后使用printWriter寫出,就行了。我們看到方法上的注解并沒有使用 @ResponseBody. 當然最好這里是在方法上加上 @ResponseBody,但是因為返回的map已經是JSON格式的,所以并不需要配置 MappingJackson2JsonView !

2)使用MappingJackson2JsonView 配合@ResponseBody來返回JSON格式

首先需要進行相關的視圖解析器的配置:

     <bean class="org.springframework.web.servlet.view.ContentNegotiatingViewResolver">        <property name="mediaTypes">            <map>                <entry key="atom" value="application/atom+xml"/>                <entry key="html" value="text/html"/>                <entry key="json" value="application/json"/>            </map>        </property>        <property name="viewResolvers">            <list>                <!-- <bean class="org.springframework.web.servlet.view.BeanNameViewResolver"/> -->                <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">                    <property name="prefix" value="/"/>                    <property name="suffix" value=".jsp"/>                </bean>            </list>        </property>        <property name="defaultViews">            <list>                <bean class="org.springframework.web.servlet.view.json.MappingJackson2JsonView" />            </list>        </property>    </bean>

這里用到了 ContentNegotiatingViewResolver ,“內容協商視圖解析器”,其實就是根據返回什么類型的視圖,就協商使用哪種視圖解析器。如果返回jsp就使用InternalResourceViewResolver視圖解析器,如果返回JSON格式就使用MappingJackson2JsonView來處理。如此而已。在 <property name="viewResolvers"> 下的<list> 標簽下,還可以加入其他的各種視圖解析器的配置。

配置了MappingJackson2JsonView 之后,就沒有必要在自己手動 JSON格式化了,上面的例子,可以改成:

    @RequiresRoles(value={"student"})    @RequestMapping(value="/queryScoreForStudent")    @ResponseBody    public Map<String, Object> queryScoreForStudent(ScoreQueryParam param, HttpSession sesion){        Student student = (Student)sesion.getAttribute(ConstantConfig.LONGIN_STUDENT);        param.setStudentId(student.getId());        PageBean<StudentScore> scoreList = this.studentCourseService.queryScoreForStudent(param);        System.out.println(JSON.toJSONString(scoreList));        if(scoreList != null && scoreList.getSize() > 0){            Map<String, Object> map = new HashMap<>();            map.put("result", "ok");            map.put("data", scoreList);            return map;        }    }

其他格式Velocity, FreeMarker, XML, PDF, Excel等視圖的處理,后面有時間在補上。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产色91| 午夜视频你懂的 | 一级网站 | 亚久久| 麻豆自拍偷拍视频 | 久久97视频 | 羞羞视频入口 | 午夜精品影院 | 又黄又爽免费无遮挡在线观看 | 亚洲精品久久久久www | 成人精品久久 | 中文字幕一二三区芒果 | 欧美成人久久 | 日本在线播放一区二区三区 | 欧美性受xxxx人人本视频 | 在线成人看片 | 亚洲欧美一区二区三区在线观看 | 嗯哈~不行好大h双性 | 久久久久久久久久久久久久久久久久 | 主播粉嫩国产在线精品 | 免费a级作爱片免费观看欧洲 | 欧美a∨亚洲欧美亚洲 | 色视频欧美 | 亚洲第九十九页 | 精品一区二区在线视频 | 亚洲免费永久 | 亚洲电影在线观看高清免费 | 午夜视频在线观看免费视频 | 国产黄色网 | 国产污污视频 | 精品一区二区三区日本 | 欧美精品一区二区三区四区 | 性欧美极品xxxx欧美一区二区 | 国产99精品视频 | 国产精品久久久久久影视 | 欧美日韩电影 | 一级空姐毛片 | 毛片在线免费观看完整版 | 日本成人在线免费 | 精品国产一二区 | 特级a欧美做爰片毛片 |