- package com.macro.mall.tiny.controller;
 
 
 
- import com.macro.mall.tiny.common.api.CommonResult;
 
- import com.macro.mall.tiny.dto.UmsAdminLoginParam;
 
- import com.macro.mall.tiny.mbg.model.UmsAdmin;
 
- import com.macro.mall.tiny.mbg.model.UmsPermission;
 
- import com.macro.mall.tiny.service.UmsAdminService;
 
- import io.swagger.annotations.Api;
 
- import io.swagger.annotations.ApiOperation;
 
- import org.springframework.beans.factory.annotation.Autowired;
 
- import org.springframework.beans.factory.annotation.Value;
 
- import org.springframework.stereotype.Controller;
 
- import org.springframework.validation.BindingResult;
 
- import org.springframework.web.bind.annotation.*;
 
 
 
- import java.util.HashMap;
 
- import java.util.List;
 
- import java.util.Map;
 
 
 
- /**
 
-  * 后臺用戶管理
 
-  * Created by macro on 2018/4/26.
 
-  */
 
- @Controller
 
- @Api(tags = "UmsAdminController", description = "后臺用戶管理")
 
- @RequestMapping("/admin")
 
- public class UmsAdminController {
 
-  ? ?@Autowired
 
-  ? ?private UmsAdminService adminService;
 
-  ? ?@Value("${jwt.tokenHeader}")
 
-  ? ?private String tokenHeader;
 
-  ? ?@Value("${jwt.tokenHead}")
 
-  ? ?private String tokenHead;
 
 
 
-  ? ?@ApiOperation(value = "用戶注冊")
 
-  ? ?@RequestMapping(value = "/register", method = RequestMethod.POST)
 
-  ? ?@ResponseBody
 
-  ? ?public CommonResult<UmsAdmin> register(@RequestBody UmsAdmin umsAdminParam, BindingResult result) {
 
-  ? ? ? ?UmsAdmin umsAdmin = adminService.register(umsAdminParam);
 
-  ? ? ? ?if (umsAdmin == null) {
 
-  ? ? ? ? ? ?CommonResult.failed();
 
-  ? ? ? ?}
 
-  ? ? ? ?return CommonResult.success(umsAdmin);
 
-  ? ?}
 
 
 
-  ? ?@ApiOperation(value = "登錄以后返回token")
 
-  ? ?@RequestMapping(value = "/login", method = RequestMethod.POST)
 
-  ? ?@ResponseBody
 
-  ? ?public CommonResult login(@RequestBody UmsAdminLoginParam umsAdminLoginParam, BindingResult result) {
 
-  ? ? ? ?String token = adminService.login(umsAdminLoginParam.getUsername(), umsAdminLoginParam.getPassword());
 
-  ? ? ? ?if (token == null) {
 
-  ? ? ? ? ? ?return CommonResult.validateFailed("用戶名或密碼錯誤");
 
-  ? ? ? ?}
 
-  ? ? ? ?Map<String, String> tokenMap = new HashMap<>();
 
-  ? ? ? ?tokenMap.put("token", token);
 
-  ? ? ? ?tokenMap.put("tokenHead", tokenHead);
 
-  ? ? ? ?return CommonResult.success(tokenMap);
 
-  ? ?}
 
 
 
-  ? ?@ApiOperation("獲取用戶所有權(quán)限(包括 -權(quán)限)")
 
-  ? ?@RequestMapping(value = "/permission/{adminId}", method = RequestMethod.GET)
 
-  ? ?@ResponseBody
 
-  ? ?public CommonResult<List<UmsPermission>> getPermissionList(@PathVariable Long adminId) {
 
-  ? ? ? ?List<UmsPermission> permissionList = adminService.getPermissionList(adminId);
 
-  ? ? ? ?return CommonResult.success(permissionList);
 
-  ? ?}
 
- }
 
- package com.macro.mall.tiny.service.impl;
 
 
 
- import com.macro.mall.tiny.common.utils.JwtTokenUtil;
 
- import com.macro.mall.tiny.dao.UmsAdminRoleRelationDao;
 
- import com.macro.mall.tiny.dto.UmsAdminLoginParam;
 
- import com.macro.mall.tiny.mbg.mapper.UmsAdminMapper;
 
- import com.macro.mall.tiny.mbg.model.UmsAdmin;
 
- import com.macro.mall.tiny.mbg.model.UmsAdminExample;
 
- import com.macro.mall.tiny.mbg.model.UmsPermission;
 
- import com.macro.mall.tiny.service.UmsAdminService;
 
- import org.slf4j.Logger;
 
- import org.slf4j.LoggerFactory;
 
- import org.springframework.beans.BeanUtils;
 
- import org.springframework.beans.factory.annotation.Autowired;
 
- import org.springframework.beans.factory.annotation.Value;
 
- import org.springframework.security.authentication.AuthenticationManager;
 
- import org.springframework.security.authentication.BadCredentialsException;
 
- import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
 
- import org.springframework.security.core.AuthenticationException;
 
- import org.springframework.security.core.context.SecurityContextHolder;
 
- import org.springframework.security.core.userdetails.UserDetails;
 
- import org.springframework.security.core.userdetails.UserDetailsService;
 
- import org.springframework.security.crypto.password.PasswordEncoder;
 
- import org.springframework.stereotype.Service;
 
 
 
- import java.util.Date;
 
- import java.util.List;
 
 
 
- /**
 
-  * UmsAdminService實(shí)現(xiàn)類
 
-  * Created by macro on 2018/4/26.
 
-  */
 
- @Service
 
- public class UmsAdminServiceImpl implements UmsAdminService {
 
-  ? ?private static final Logger LOGGER = LoggerFactory.getLogger(UmsAdminServiceImpl.class);
 
-  ? ?@Autowired
 
-  ? ?private UserDetailsService userDetailsService;
 
-  ? ?@Autowired
 
-  ? ?private JwtTokenUtil jwtTokenUtil;
 
-  ? ?@Autowired
 
-  ? ?private PasswordEncoder passwordEncoder;
 
-  ? ?@Value("${jwt.tokenHead}")
 
-  ? ?private String tokenHead;
 
-  ? ?@Autowired
 
-  ? ?private UmsAdminMapper adminMapper;
 
-  ? ?@Autowired
 
-  ? ?private UmsAdminRoleRelationDao adminRoleRelationDao;
 
 
 
-  ? ?@Override
 
-  ? ?public UmsAdmin getAdminByUsername(String username) {
 
-  ? ? ? ?UmsAdminExample example = new UmsAdminExample();
 
-  ? ? ? ?example.createCriteria().andUsernameEqualTo(username);
 
-  ? ? ? ?List<UmsAdmin> adminList = adminMapper.selectByExample(example);
 
-  ? ? ? ?if (adminList != null && adminList.size() > 0) {
 
-  ? ? ? ? ? ?return adminList.get(0);
 
-  ? ? ? ?}
 
-  ? ? ? ?return null;
 
-  ? ?}
 
 
 
-  ? ?@Override
 
-  ? ?public UmsAdmin register(UmsAdmin umsAdminParam) {
 
-  ? ? ? ?UmsAdmin umsAdmin = new UmsAdmin();
 
-  ? ? ? ?BeanUtils.copyProperties(umsAdminParam, umsAdmin);
 
-  ? ? ? ?umsAdmin.setCreateTime(new Date());
 
-  ? ? ? ?umsAdmin.setStatus(1);
 
-  ? ? ? ?//查詢是否有相同用戶名的用戶
 
-  ? ? ? ?UmsAdminExample example = new UmsAdminExample();
 
-  ? ? ? ?example.createCriteria().andUsernameEqualTo(umsAdmin.getUsername());
 
-  ? ? ? ?List<UmsAdmin> umsAdminList = adminMapper.selectByExample(example);
 
-  ? ? ? ?if (umsAdminList.size() > 0) {
 
-  ? ? ? ? ? ?return null;
 
-  ? ? ? ?}
 
-  ? ? ? ?//將密碼進(jìn)行加密操作
 
-  ? ? ? ?String encodePassword = passwordEncoder.encode(umsAdmin.getPassword());
 
-  ? ? ? ?umsAdmin.setPassword(encodePassword);
 
-  ? ? ? ?adminMapper.insert(umsAdmin);
 
-  ? ? ? ?return umsAdmin;
 
-  ? ?}
 
 
 
-  ? ?@Override
 
-  ? ?public String login(String username, String password) {
 
-  ? ? ? ?String token = null;
 
-  ? ? ? ?try {
 
-  ? ? ? ? ? ?UserDetails userDetails = userDetailsService.loadUserByUsername(username);
 
-  ? ? ? ? ? ?if (!passwordEncoder.matches(password, userDetails.getPassword())) {
 
-  ? ? ? ? ? ? ? ?throw new BadCredentialsException("密碼不正確");
 
-  ? ? ? ? ? ?}
 
-  ? ? ? ? ? ?UsernamePasswordAuthenticationToken authentication = new UsernamePasswordAuthenticationToken(userDetails, null, userDetails.getAuthorities());
 
-  ? ? ? ? ? ?SecurityContextHolder.getContext().setAuthentication(authentication);
 
-  ? ? ? ? ? ?token = jwtTokenUtil.generateToken(userDetails);
 
-  ? ? ? ?} catch (AuthenticationException e) {
 
-  ? ? ? ? ? ?LOGGER.warn("登錄異常:{}", e.getMessage());
 
-  ? ? ? ?}
 
-  ? ? ? ?return token;
 
-  ? ?}
 
 
 
 
 
-  ? ?@Override
 
-  ? ?public List<UmsPermission> getPermissionList(Long adminId) {
 
-  ? ? ? ?return adminRoleRelationDao.getPermissionList(adminId);
 
-  ? ?}
 
- }
 
- package com.macro.mall.tiny.config;
 
 
 
- import org.springframework.context.annotation.Bean;
 
- import org.springframework.context.annotation.Configuration;
 
- import springfox.documentation.builders.ApiInfoBuilder;
 
- import springfox.documentation.builders.PathSelectors;
 
- import springfox.documentation.builders.RequestHandlerSelectors;
 
- import springfox.documentation.service.ApiInfo;
 
- import springfox.documentation.service.ApiKey;
 
- import springfox.documentation.service.AuthorizationScope;
 
- import springfox.documentation.service.SecurityReference;
 
- import springfox.documentation.spi.DocumentationType;
 
- import springfox.documentation.spi.service.contexts.SecurityContext;
 
- import springfox.documentation.spring.web.plugins.Docket;
 
- import springfox.documentation.swagger2.annotations.EnableSwagger2;
 
 
 
- import java.util.ArrayList;
 
- import java.util.List;
 
 
 
- /**
 
-  * Swagger2API文檔的配置
 
-  */
 
- @Configuration
 
- @EnableSwagger2
 
- public class Swagger2Config {
 
-  ? ?@Bean
 
-  ? ?public Docket createRestApi(){
 
-  ? ? ? ?return new Docket(DocumentationType.SWAGGER_2)
 
-  ? ? ? ? ? ? ? ?.apiInfo(apiInfo())
 
-  ? ? ? ? ? ? ? ?.select()
 
-  ? ? ? ? ? ? ? ?//為當(dāng)前包下controller生成API文檔
 
-  ? ? ? ? ? ? ? ?.apis(RequestHandlerSelectors.basePackage("com.macro.mall.tiny.controller"))
 
-  ? ? ? ? ? ? ? ?.paths(PathSelectors.any())
 
-  ? ? ? ? ? ? ? ?.build()
 
-  ? ? ? ? ? ? ? ?//添加登錄認(rèn)證
 
-  ? ? ? ? ? ? ? ?.securitySchemes(securitySchemes())
 
-  ? ? ? ? ? ? ? ?.securityContexts(securityContexts());
 
-  ? ?}
 
 
 
-  ? ?private ApiInfo apiInfo() {
 
-  ? ? ? ?return new ApiInfoBuilder()
 
-  ? ? ? ? ? ? ? ?.title("SwaggerUI演示")
 
-  ? ? ? ? ? ? ? ?.description("mall-tiny")
 
-  ? ? ? ? ? ? ? ?.contact("macro")
 
-  ? ? ? ? ? ? ? ?.version("1.0")
 
-  ? ? ? ? ? ? ? ?.build();
 
-  ? ?}
 
 
 
-  ? ?private List<ApiKey> securitySchemes() {
 
-  ? ? ? ?//設(shè)置請求頭信息
 
-  ? ? ? ?List<ApiKey> result = new ArrayList<>();
 
-  ? ? ? ?ApiKey apiKey = new ApiKey("Authorization", "Authorization", "header");
 
-  ? ? ? ?result.add(apiKey);
 
-  ? ? ? ?return result;
 
-  ? ?}
 
 
 
-  ? ?private List<SecurityContext> securityContexts() {
 
-  ? ? ? ?//設(shè)置需要登錄認(rèn)證的路徑
 
-  ? ? ? ?List<SecurityContext> result = new ArrayList<>();
 
-  ? ? ? ?result.add(getContextByPath("/brand/.*"));
 
-  ? ? ? ?return result;
 
-  ? ?}
 
 
 
-  ? ?private SecurityContext getContextByPath(String pathRegex){
 
-  ? ? ? ?return SecurityContext.builder()
 
-  ? ? ? ? ? ? ? ?.securityReferences(defaultAuth())
 
-  ? ? ? ? ? ? ? ?.forPaths(PathSelectors.regex(pathRegex))
 
-  ? ? ? ? ? ? ? ?.build();
 
-  ? ?}
 
 
 
-  ? ?private List<SecurityReference> defaultAuth() {
 
-  ? ? ? ?List<SecurityReference> result = new ArrayList<>();
 
-  ? ? ? ?AuthorizationScope authorizationScope = new AuthorizationScope("global", "accessEverything");
 
-  ? ? ? ?AuthorizationScope[] authorizationScopes = new AuthorizationScope[1];
 
-  ? ? ? ?authorizationScopes[0] = authorizationScope;
 
-  ? ? ? ?result.add(new SecurityReference("Authorization", authorizationScopes));
 
-  ? ? ? ?return result;
 
-  ? ?}
 
- }