Controller層的寫法

項目中的兩個Controller層實現類,一個是跳轉到jsp頁面,一個是以Json形式返回Map鍵值對。html

跳轉到jsp頁面:java

 1 package com.controller;
 2 
 3 import java.io.IOException;
 4 
 5 import javax.servlet.http.HttpServletRequest;
 6 
 7 import org.apache.commons.httpclient.HttpClient;
 8 import org.apache.commons.httpclient.HttpException;
 9 import org.apache.commons.httpclient.methods.PostMethod;
10 import org.springframework.stereotype.Controller;
11 import org.springframework.web.bind.annotation.RequestMapping;
12 import org.springframework.web.servlet.ModelAndView;
13 
14 import util.AuthConfig;
15 
16 @Controller
17 public class Operate {
18     @RequestMapping(value="login.html")
19     public ModelAndView requestPost(HttpServletRequest request){
20         AuthConfig config = AuthConfig.getInstance();
21         String server = config.getConfigParameter("server");
22         String client_id = config.getConfigParameter("client_id");
23         String client_secret = config.getConfigParameter("client_secret");
24         String redirect_uri = config.getConfigParameter("redirect_uri");
25         String scope = config.getConfigParameter("scope");
26         String url = server+"AuthServer/oauth2/authorize?client_id="+client_id+"&client_secret="+client_secret+"&redirect_uri="+redirect_uri+"&response_type=code&scope="+scope;
27         System.out.println(url);
28         ModelAndView mav = new ModelAndView("login");
29         mav.addObject("url", url);
30         return mav;
31     }
32 }

一個是以Json形式返回Map鍵值對:web

 1 package com.bupt.auth.controller;
 2 
 3 import java.util.HashMap;
 4 import java.util.Map;
 5 
 6 import com.bupt.oauth2.token.AuthKeyGenerator;
 7 import com.bupt.oauth2.token.DefaultAuthKeyGenerator;
 8 import com.bupt.oauth2.utils.*;
 9 
10 import org.springframework.beans.factory.annotation.Autowired;
11 
12 import com.bupt.oauth2.common.OAuth2AccessToken;
13 
14 import org.springframework.web.bind.annotation.RequestBody;
15 import org.springframework.web.bind.annotation.RequestMapping;
16 import org.springframework.web.bind.annotation.RequestMethod;
17 import org.springframework.web.bind.annotation.ResponseBody;
18 import org.springframework.web.bind.annotation.RestController;
19 
20 import com.bupt.auth.bussiness.RegisterAppBean;
21 import com.bupt.auth.bussiness.RegisterBean;
22 import com.bupt.auth.entity.User;
23 import com.bupt.auth.exception.MyException;
24 import com.bupt.auth.service.UserManager;
25 import com.bupt.oauth2.peve.TokenHandler;
26 import com.bupt.oauth2.common.util.OAuth2Utils;
27 import com.bupt.oauth2.common.util.VePeUtils;
28 
29 @RestController
30 public class RegisteController 
31 {
32     @Autowired
33     private TokenHandler tokenHandler;
34     @Autowired
35     private UserManager userManager;
36     
37     private AuthKeyGenerator authKeyGenerator = new DefaultAuthKeyGenerator();
38     
39     @RequestMapping(value="/registeruser.html",method=RequestMethod.POST)
40     @ResponseBody
41     public Map<String, Object> register(@RequestBody RegisterBean registerbean)
42     {
43         Map<String, Object> map = new HashMap<String, Object>();
44         User user = new User();
45         try{
46             if(userManager.findByUsername(registerbean.getUser_name()) != null){
47                 map.put("result", "fail");
48                 map.put("info", "Username has already exist!!");
49                 map.put("failcode", "602");
50                 return map;
51             }
52         }catch(MyException e){
53             map.put("result", "fail");
54             map.put("info", e.getMessage());
55             map.put("failcode", e.getFailCode());
56             return map;
57         }
58         
59         user.setUsername(registerbean.getUser_name());
60         user.setPassword(registerbean.getUser_password());
61         user.setInfo(registerbean.getInfo());
62         userManager.addUser(user);
63         
64         createUserAccessToken(user);
65         System.out.println(registerbean.getUser_name());
66         
67         map.put("result", "success");
68         return map;
69     }
70     
71     private void createUserAccessToken(User user)
72     {
73         String userName = user.getUsername();
74         String userId = String.valueOf(user.getId());
75         Map<String, String> requestParameters =  VePeUtils.buildRequestParameters(userId, null);
76         tokenHandler.accessToken(requestParameters);
77         //user 中存放authentication_id
78         //與JdbcTokenStore中storeAccessToken方法中生成authentication_id相對應
79         user.setAccesstoken(authKeyGenerator.extractKeyByVePeCredentials(user.toString()));
80         userManager.updateUser(user);
81     }
82 }
相關文章
相關標籤/搜索