96SEO 2026-02-19 19:35 12
org.apache.http.client.methods.CloseableHttpResponse;

org.apache.http.client.methods.HttpGet;
org.apache.http.client.methods.HttpPost;
org.apache.http.entity.StringEntity;
org.apache.http.impl.client.CloseableHttpClient;
org.apache.http.impl.client.HttpClients;
org.apache.http.util.EntityUtils;
org.springframework.boot.test.context.SpringBootTest;import
java.io.UnsupportedEncodingException;SpringBootTest
测试通过HttpClientTest发送GET请求*/Testpublic
Exception{//创建HTTP对象CloseableHttpClient
HttpClients.createDefault();//创建请求对象HttpGet
HttpGet(http://localhost:8080/user/shop/status);//发送请求CloseableHttpResponse
httpClient.execute(httpGet);//获取服务端返回的状态码int
response.getStatusLine().getStatusCode();System.out.println(服务端返回状态码statusCode);HttpEntity
EntityUtils.toString(entity);System.out.println(服务端返回数据为body);//关闭资源response.close();httpClient.close();}/***
测试通过HttpClientTest发送POST请求*/Testpublic
HttpClients.createDefault();//创建请求对象HttpPost
HttpPost(http://localhost:8080/admin/employee/login);//构造JSON对象JSONObject
JSONObject();jsonObject.put(username,
admin);jsonObject.put(password,
StringEntity(jsonObject.toString());//指定请求编码方式entity.setContentEncoding(utf-8);//数据格式entity.setContentType(application/json);httpPost.setEntity(entity);//发送请求CloseableHttpResponse
httpClient.execute(httpPost);//解析返回结果int
response.getStatusLine().getStatusCode();System.out.println(响应码为
EntityUtils.toString(entity1);System.out.println(响应数据为body);//关闭请求response.close();httpClient.close();}
登录后进入开发管理和管理根据页面提示信息补充小程序各项基本信息并生成密钥。
bind:tapgetUserInfo获取用户信息/button昵称:
world,nickName:,url:},//获取微信用户头像和昵称getUserInfo(){wx.getUserProfile({desc:
{console.log(res.userInfo)//为数据赋值this.setData({nickName:
其中需要调整数据库到2.7以下版本。
具体路径为右上角详情-本地设置-调试基础库。
world,nickName:,url:,code:},//微信登录获取微信登录的授权码wxlogin(){wx.login({success:
{console.log(res.code)this.setData({code:
bind:tapwxlogin微信登录/button授权码{{code}}/view发送请求
//发送请求sendRequest(){wx.request({url:
http://localhost:8080/user/shop/status,method:GET,success:
(res){//代表后端响应的整个JSON数据console.log(res.data)}})}viewbutton
bind:tapsendRequest发送请求/button/view微信登录
return*/PostMapping(/login)ApiOperation(微信登录)public
userLoginDTO){log.info(微信用户登录:{},userLoginDTO.getCode());//微信登录User
userService.wxLogin(userLoginDTO);//为微信用户生成令牌MapString,Object
HashMap();claims.put(JwtClaimsConstant.USER_ID,user.getId());String
JwtUtil.createJWT(jwtProperties.getUserSecretKey(),
UserLoginVO.builder().id(user.getId()).openid(user.getOpenid()).token(token).build();return
https://api.weixin.qq.com/sns/jscode2session;Autowiredprivate
weChatProperties;Autowiredprivate
getOpenid(userLoginDTO.getCode());//判断openid是否为空如果为空表示登录失败抛出业务异常if(openid
LoginFailedException(MessageConstant.LOGIN_FAILED);}//是否是新用户User
userMapper.getByOpenID(openid);//是新用户自动完成注册if
User.builder().openid(openid).createTime(LocalDateTime.now()).build();}userMapper.insert(user);//返回用户对象return
code){//调用微信服务器接口服务获得当前微信服务的openidMapString,String
HashMap();map.put(appid,weChatProperties.getAppid());map.put(secret,
weChatProperties.getSecret());map.put(js_code,
jsonObject.getString(openid);return
3.0//ENhttp://mybatis.org/dtd/mybatis-3-mapper.dtd
namespacecom.sky.mapper.UserMapperinsert
VALUES(#{openid},#{name},#{phone},#{sex},#{idNumber},#{avatar},#{createTime})/insert
classpath:/META-INF/resources/下寻找对应的静态资源。
*
这样做的好处是可以将一些静态资源集中存放在指定的目录而不需要暴露给外部直接访问项目的文件结构。
*
这有助于更好地组织项目结构同时提供对静态资源的有效管理和映射。
*
addResourceHandlers(ResourceHandlerRegistry
{log.info(开始设置静态资源映射);registry.addResourceHandler(/doc.html).addResourceLocations(classpath:/META-INF/resources/);registry.addResourceHandler(/webjars/**).addResourceLocations(classpath:/META-INF/resources/webjars/);/***
extendMessageConverters(ListHttpMessageConverter?
{log.info(扩展消息转换器..);//创建一个消息转换器对象MappingJackson2HttpMessageConverter
MappingJackson2HttpMessageConverter();//需要为消息转换器设置一个对象转换器可以将Java对象序列化为json数据converter.setObjectMapper(new
JacksonObjectMapper());//将自己的消息转换器加入容器中converters.add(0,converter);}/***
/admin/**下但排除了路径/admin/employee/login。
*
/user/**下但排除了路径/user/user/login和/user/shop/status。
*
这样配置的效果是当请求路径匹配拦截路径时会触发相应的拦截器执行相应的逻辑。
拦截器可以用于处理请求前的预处理、日志记录、权限验证等工作。
*
addInterceptors(InterceptorRegistry
{log.info(开始注册自定义拦截器...);registry.addInterceptor(jwtTokenAdminInterceptor).addPathPatterns(/admin/**).excludePathPatterns(/admin/employee/login);registry.addInterceptor(jwtTokenUserInterceptor).addPathPatterns(/user/**).excludePathPatterns(/user/user/login).excludePathPatterns(/user/shop/status);}对jwt拦截器的理解
{//获取当前线程idSystem.out.println(当前线程idThread.currentThread().getId());//判断当前拦截到的是Controller的方法还是其他资源if
request.getHeader(jwtProperties.getUserTokenName());//2、校验令牌try
解析方法接受两个参数第一个是用于解密的密钥//第二个是待解析的
JwtUtil.parseJWT(jwtProperties.getUserSecretKey(),
对象中获取用户ID的声明并将其转换成Long类型。
在JWT的声明中通常会包含一些声明比如过期时间、签发者等//
Long.valueOf(claims.get(JwtClaimsConstant.USER_ID).toString());log.info(当前用户id,
userId);//在拦截器中存入//这行代码的作用是将用户ID存入线程上下文。
线程上下文是一个与线程关联的数据存储区域可以在整个线程的生命周期内共享数据。
//在这个具体的场景中当用户的
令牌验证通过后将用户的ID存入线程上下文以便在后续的业务逻辑中能够方便地获取当前用户的ID//而不必在每个方法参数中传递用户ID或者从其他地方再次获取。
这样做的好处是简化了代码提高了代码的可读性和可维护性。
//举例来说如果有其他地方需要使用当前用户的ID可以通过
获取//而不必传递用户ID的参数。
这在涉及多个方法、类之间需要传递用户ID的情况下可以减少重复代码提高开发效率。
BaseContext.setCurrentId(userId);//3、通过放行return
{//4、不通过响应401状态码response.setStatus(401);return
Controller层注意对注释进行命名用来区别admin的相同请求具体实现方法可以通用。
RestController(userCategoryController)
默认会按照参数名字和请求中的参数名字进行匹配。
在你的情况下接口路径为
的一种简化规则适用于一些简单的情况。
GetMapping(/list)ApiOperation(条件查询)/***
categoryService.list(type);return
RestController(userDishController)
return*/GetMapping(/list)ApiOperation(根据分类id查询菜品)private
dishService.listWithFlavor(categoryId);return
Result.success(dishVOS);}Service实现层
Dish.builder().categoryId(categoryId).status(StatusConstant.ENABLE).build();ListDish
dishMapper.list(dish);ListDishVO
DishVO();BeanUtils.copyProperties(d,
dishFlavorMapper.getByDishId(d.getId());dishVO.setFlavors(dishFlavorList);dishVOList.add(dishVO);}return
RestController(userSetmealController)
return*/GetMapping(/list)ApiOperation(根据分类id查询套餐)public
setmealService.list(categoryId);return
return*/ApiOperation(根据套餐id查询包含的菜品)GetMapping(/dish/{id})public
setmealService.dishList(id);return
Result.success(dishItemVOS);}Service层实现类
Setmeal();setmeal.setCategoryId(categoryId);setmeal.setStatus(StatusConstant.ENABLE);ListSetmeal
setmealMapper.list(setmeal);return
setmealMapper.dishList(id);}Mapper接口
sd.name,sd.copies,d.image,d.description
resultTypecom.sky.entity.Setmeal
作为专业的SEO优化服务提供商,我们致力于通过科学、系统的搜索引擎优化策略,帮助企业在百度、Google等搜索引擎中获得更高的排名和流量。我们的服务涵盖网站结构优化、内容优化、技术SEO和链接建设等多个维度。
| 服务项目 | 基础套餐 | 标准套餐 | 高级定制 |
|---|---|---|---|
| 关键词优化数量 | 10-20个核心词 | 30-50个核心词+长尾词 | 80-150个全方位覆盖 |
| 内容优化 | 基础页面优化 | 全站内容优化+每月5篇原创 | 个性化内容策略+每月15篇原创 |
| 技术SEO | 基本技术检查 | 全面技术优化+移动适配 | 深度技术重构+性能优化 |
| 外链建设 | 每月5-10条 | 每月20-30条高质量外链 | 每月50+条多渠道外链 |
| 数据报告 | 月度基础报告 | 双周详细报告+分析 | 每周深度报告+策略调整 |
| 效果保障 | 3-6个月见效 | 2-4个月见效 | 1-3个月快速见效 |
我们的SEO优化服务遵循科学严谨的流程,确保每一步都基于数据分析和行业最佳实践:
全面检测网站技术问题、内容质量、竞争对手情况,制定个性化优化方案。
基于用户搜索意图和商业目标,制定全面的关键词矩阵和布局策略。
解决网站技术问题,优化网站结构,提升页面速度和移动端体验。
创作高质量原创内容,优化现有页面,建立内容更新机制。
获取高质量外部链接,建立品牌在线影响力,提升网站权威度。
持续监控排名、流量和转化数据,根据效果调整优化策略。
基于我们服务的客户数据统计,平均优化效果如下:
我们坚信,真正的SEO优化不仅仅是追求排名,而是通过提供优质内容、优化用户体验、建立网站权威,最终实现可持续的业务增长。我们的目标是与客户建立长期合作关系,共同成长。
Demand feedback