diff --git a/yudao-framework/yudao-spring-boot-starter-security/src/main/java/cn/iocoder/yudao/framework/security/core/util/SecurityFrameworkUtils.java b/yudao-framework/yudao-spring-boot-starter-security/src/main/java/cn/iocoder/yudao/framework/security/core/util/SecurityFrameworkUtils.java index ba81dca34..5890e855a 100644 --- a/yudao-framework/yudao-spring-boot-starter-security/src/main/java/cn/iocoder/yudao/framework/security/core/util/SecurityFrameworkUtils.java +++ b/yudao-framework/yudao-spring-boot-starter-security/src/main/java/cn/iocoder/yudao/framework/security/core/util/SecurityFrameworkUtils.java @@ -1,5 +1,6 @@ package cn.iocoder.yudao.framework.security.core.util; +import cn.iocoder.yudao.framework.common.enums.UserTypeEnum; import cn.iocoder.yudao.framework.security.core.LoginUser; import cn.iocoder.yudao.framework.web.core.util.WebFrameworkUtils; import org.springframework.lang.Nullable; @@ -11,6 +12,7 @@ import org.springframework.security.web.authentication.WebAuthenticationDetailsS import org.springframework.util.StringUtils; import javax.servlet.http.HttpServletRequest; +import java.util.Objects; import java.util.Set; /** @@ -100,7 +102,9 @@ public class SecurityFrameworkUtils { WebFrameworkUtils.setLoginUserId(request, loginUser.getId()); WebFrameworkUtils.setLoginUserType(request, loginUser.getUserType()); // TODO @jason:使用 userId 会不会更合适哈? - org.activiti.engine.impl.identity.Authentication.setAuthenticatedUserId(loginUser.getUsername()); + if (Objects.equals(UserTypeEnum.ADMIN.getValue(), loginUser.getUserType())) { + org.activiti.engine.impl.identity.Authentication.setAuthenticatedUserId(loginUser.getUsername()); + } } } diff --git a/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/member/controller/user/SysUserProfileController.http b/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/member/controller/user/SysUserProfileController.http index 1ce9eea62..26bd55aaf 100644 --- a/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/member/controller/user/SysUserProfileController.http +++ b/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/member/controller/user/SysUserProfileController.http @@ -1,11 +1,11 @@ -### 请求 /system/user/profile/get 接口 => 没有权限 -GET {{userServerUrl}}/system/user/profile/get +### 请求 /member/user/profile/get 接口 => 没有权限 +GET {{userServerUrl}}/member/user/profile/get Authorization: Bearer test245 -### 请求 /system/user/profile/revise-nickname 接口 成功 -PUT {{userServerUrl}}/system/user/profile/update-nickname?nickName=yunai222 +### 请求 /member/user/profile/revise-nickname 接口 成功 +PUT {{userServerUrl}}/member/user/profile/update-nickname?nickName=yunai222 Authorization: Bearer test245 -### 请求 /system/user/profile/get-user-info 接口 成功 -GET {{userServerUrl}}/system/user/profile/get-user-info?id=245 -Authorization: Bearer test245 \ No newline at end of file +### 请求 /member/user/profile/get-user-info 接口 成功 +GET {{userServerUrl}}/member/user/profile/get-user-info?id=245 +Authorization: Bearer test245 diff --git a/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/member/controller/user/SysUserProfileController.java b/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/member/controller/user/SysUserProfileController.java index b2afbc78b..93149e793 100644 --- a/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/member/controller/user/SysUserProfileController.java +++ b/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/member/controller/user/SysUserProfileController.java @@ -27,7 +27,7 @@ import static cn.iocoder.yudao.userserver.modules.member.enums.MbrErrorCodeConst @Api(tags = "用户个人中心") @RestController -@RequestMapping("/system/user/profile") +@RequestMapping("/member/user/profile") @Validated @Slf4j public class SysUserProfileController { @@ -57,14 +57,13 @@ public class SysUserProfileController { return success(avatar); } - @GetMapping("/get-user-info") - @ApiOperation("获取用户头像与昵称") + @GetMapping("/get") + @ApiOperation("获得基本信息") @PreAuthenticated public CommonResult getUserInfo() { return success(userService.getUserInfo(getLoginUserId())); } - @PostMapping("/update-mobile") @ApiOperation(value = "修改用户手机") @PreAuthenticated diff --git a/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/member/service/user/MbrUserService.java b/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/member/service/user/MbrUserService.java index e45763dd3..fc5a8564d 100644 --- a/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/member/service/user/MbrUserService.java +++ b/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/member/service/user/MbrUserService.java @@ -65,6 +65,7 @@ public interface MbrUserService { /** * 根据用户id,获取用户头像与昵称 + * * @param userId 用户id * @return 用户响应实体类 */ diff --git a/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/system/controller/auth/SysAuthController.java b/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/system/controller/auth/SysAuthController.java index 4dfdb7a8c..9e6b9f450 100644 --- a/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/system/controller/auth/SysAuthController.java +++ b/yudao-user-server/src/main/java/cn/iocoder/yudao/userserver/modules/system/controller/auth/SysAuthController.java @@ -40,7 +40,6 @@ public class SysAuthController { @Resource private SysSocialService socialService; - @PostMapping("/login") @ApiOperation("使用手机 + 密码登录") public CommonResult login(@RequestBody @Valid SysAuthLoginReqVO reqVO) { diff --git a/yudao-vue-ui/App.vue b/yudao-vue-ui/App.vue index 6b658ecf3..c3369b1b6 100644 --- a/yudao-vue-ui/App.vue +++ b/yudao-vue-ui/App.vue @@ -1,19 +1,105 @@ - \ No newline at end of file + + .lazyload{ + position: relative; + + &.lazypic{ + &:after{ + content: ''; + position: absolute; + left: 0; + top: 0; + width: 100%; + height: 100%; + background-image: url(); + background-size: 100% 100%; + opacity: 0.3; + } + } + image{ + position: relative; + z-index: 1; + opacity: 0; + } + &.loaded image{ + transition: .7s; + opacity: 1 !important; + } + } + diff --git a/yudao-vue-ui/api/member/userProfile.js b/yudao-vue-ui/api/member/userProfile.js new file mode 100644 index 000000000..3c3d52e71 --- /dev/null +++ b/yudao-vue-ui/api/member/userProfile.js @@ -0,0 +1,9 @@ +import { request } from '@/common/js/request.js' + +// 获得用户的基本信息 +export function getUserInfo() { + return request({ + url: 'member/user/profile/get', + method: 'get' + }) +} \ No newline at end of file diff --git a/yudao-vue-ui/api/system/auth.js b/yudao-vue-ui/api/system/auth.js new file mode 100644 index 000000000..81089a03f --- /dev/null +++ b/yudao-vue-ui/api/system/auth.js @@ -0,0 +1,27 @@ +import { request } from '@/common/js/request.js' + +// 手机号 + 密码登陆 +export function login(mobile, password) { + const data = { + mobile, + password + } + return request({ + url: 'login', + method: 'post', + data: data + }) +} + +// 手机号 + 验证码登陆 +export function smsLogin(mobile, code) { + const data = { + mobile, + code + } + return request({ + url: 'sms-login', + method: 'post', + data: data + }) +} \ No newline at end of file diff --git a/yudao-vue-ui/common/js/request.js b/yudao-vue-ui/common/js/request.js index a1f324f2f..459cdb25b 100644 --- a/yudao-vue-ui/common/js/request.js +++ b/yudao-vue-ui/common/js/request.js @@ -1,18 +1,18 @@ const BASE_URL = 'http://127.0.0.1:28080/api/'; -import { msg } from './util' +import { msg, getAuthToken } from './util' export const request = (options) => { return new Promise((resolve, reject) => { // 发起请求 + const authToken = getAuthToken(); uni.request({ url: BASE_URL + options.url, method: options.method || 'GET', data: options.data || {}, header: { - 'Authorization': '' // TODO 芋艿:带 token + 'Authorization': authToken ? `Bearer ${authToken}` : '' } }).then(res => { - debugger res = res[1]; const statusCode = res.statusCode; if (statusCode !== 200) { diff --git a/yudao-vue-ui/common/js/util.js b/yudao-vue-ui/common/js/util.js index 13ab716a9..d253d047e 100644 --- a/yudao-vue-ui/common/js/util.js +++ b/yudao-vue-ui/common/js/util.js @@ -34,14 +34,103 @@ export const throttle = (fn, delay=500) => { } /** - * toast + * toast 提示 + * + * @param {String} title 标题 + * @param {Object} param 拓展参数 + * @param {Integer} param.duration 持续时间 + * @param {Boolean} param.mask 是否遮罩 + * @param {Boolean} param.icon 图标 */ export const msg = (title = '', param={}) => { - if(!title) return; + if (!title) { + return; + } uni.showToast({ title, duration: param.duration || 1500, mask: param.mask || false, - icon: param.icon || 'none' + icon: param.icon || 'none' // TODO 芋艿:是否要区分下 error 的提示,或者专门的封装 }); +} + +/** + * 检查登录 + * + * @param {Boolean} options.nav 如果未登陆,是否跳转到登陆页。默认为 true + * @return {Boolean} 是否登陆 + */ +export const isLogin = (options = {}) => { + const token = this.getAuthToken(); + if (token) { + return true; + } + // 若 nav 不为 false,则进行跳转登陆页 + if (options.nav !== false) { + uni.navigateTo({ + url: '/pages/auth/login' + }) + } + return false; +} + +/** + * 获得认证 Token + * + * @return 认证 Token + */ +export const getAuthToken = () => { + return uni.getStorageSync('token'); +} + +/** + * 校验参数 + * + * @param {String} 字符串 + * @param {String} 数据的类型。例如说 mobile 手机号、tel 座机 TODO 芋艿:是否组件里解决 + */ +export const checkStr = (str, type) => { + switch (type) { + case 'mobile': //手机号码 + return /^1[3|4|5|6|7|8|9][0-9]{9}$/.test(str); + case 'tel': //座机 + return /^(0\d{2,3}-\d{7,8})(-\d{1,4})?$/.test(str); + case 'card': //身份证 + return /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/.test(str); + case 'mobileCode': //6位数字验证码 + return /^[0-9]{6}$/.test(str) + case 'pwd': //密码以字母开头,长度在6~18之间,只能包含字母、数字和下划线 + return /^([a-zA-Z0-9_]){6,18}$/.test(str) + case 'payPwd': //支付密码 6位纯数字 + return /^[0-9]{6}$/.test(str) + case 'postal': //邮政编码 + return /[1-9]\d{5}(?!\d)/.test(str); + case 'QQ': //QQ号 + return /^[1-9][0-9]{4,9}$/.test(str); + case 'email': //邮箱 + return /^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/.test(str); + case 'money': //金额(小数点2位) + return /^\d*(?:\.\d{0,2})?$/.test(str); + case 'URL': //网址 + return /(http|ftp|https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-\.,@?^=%&:/~\+#]*[\w\-\@?^=%&/~\+#])?/.test(str) + case 'IP': //IP + return /((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d))/.test(str); + case 'date': //日期时间 + return /^(\d{4})\-(\d{2})\-(\d{2}) (\d{2})(?:\:\d{2}|:(\d{2}):(\d{2}))$/.test(str) || /^(\d{4})\-(\d{2})\-(\d{2})$/ + .test(str) + case 'number': //数字 + return /^[0-9]$/.test(str); + case 'english': //英文 + return /^[a-zA-Z]+$/.test(str); + case 'chinese': //中文 + return /^[\\u4E00-\\u9FA5]+$/.test(str); + case 'lower': //小写 + return /^[a-z]+$/.test(str); + case 'upper': //大写 + return /^[A-Z]+$/.test(str); + case 'HTML': //HTML标记 + return /<("[^"]*"|'[^']*'|[^'">])*>/.test(str); + default: + return true; + } } \ No newline at end of file diff --git a/yudao-vue-ui/pages/auth/login.vue b/yudao-vue-ui/pages/auth/login.vue index f7dc0902f..df5f8e7a3 100644 --- a/yudao-vue-ui/pages/auth/login.vue +++ b/yudao-vue-ui/pages/auth/login.vue @@ -42,7 +42,7 @@ placeholder="请输入密码" placeholder-style="color: #909399"/> - + @@ -78,9 +78,11 @@