swagger配置

1.maven依赖
(第一个后台/v2/api-do,第二个UI页面引用的jar包,版本2.6.1)
       <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.6.1</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.6.1</version>
        </dependency>
2.Swagger配置文件
@Configuration    // 配置注解,自动在本类上下文加载一些环境变量信息
@EnableSwagger2   // 使swagger2生效
@EnableWebMvc
@ComponentScan(basePackages = {“com.enation.app.javashop.xiaochengxu.action.api”})  //需要扫描的包路径
public class SwaggerConfig extends WebMvcConfigurationSupport {
@Bean
public Docket createRestApi() {
return new Docket(DocumentationType.SWAGGER_2)
.select()
.apis(RequestHandlerSelectors.any())
.paths(PathSelectors.any())
.build();
}
}
3.web.xml配置说明
(说明:Springmvc前端控制器扫描路径增加“/v2/api-docs”,用于扫描Swagger的 /v2/api-docs,否则 /v2/api-docs无法生效,备注spring的映射一定要是/,否则swagger2中需要引入相关静态资源可能会因为找不到而导致页面加载失败。)
<servlet-mapping>
        <servlet-name>spring-servlet</servlet-name>
        <url-pattern>/swagger-resources</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
        <servlet-name>spring-servlet</servlet-name>
        <url-pattern>/v2/api-docs</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
        <servlet-name>spring-servlet</servlet-name>
        <url-pattern>/swagger-resources/configuration/ui</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
        <servlet-name>spring-servlet</servlet-name>
        <url-pattern>/swagger-resources/configuration/security</url-pattern>
    </servlet-mapping>
4.spring-mvc.xml 增加自动扫描Swagger
<!– 配置Swagger相关静态资源 –>
(Spring的url-pattern映射关系为 /:映射到classpath:/META-INF/resources/下的一个jar里面有swagger-ui.html,用于springmvc自动扫描那个模板和相关js)
<mvc:resources location=”classpath:/META-INF/resources/” mapping=”swagger-ui.html”/>
    <mvc:resources location=”classpath:/META-INF/resources/webjars/” mapping=”/webjars/**”/>
5.freemarker拦截的处理办法
// 前台处理器
 if (uri.endsWith(“.html”) && !(uri.indexOf(“swagger”) >= 0)){
        eopProcessor = new FacadeProcessor();
 }
6.Controller中使用注解添加API文档
@RestController
@RequestMapping(“/api/xcx/adv”)
@Api(description = “获取首页广告接口”)
@Validated
public class AdvApiController {
@Autowired
private IAdvManager advManager;@ApiOperation(value = “根据某个广告id获取广告信息接口”, notes = “根据某个广告id获取广告信息”)
@ApiImplicitParams({ @ApiImplicitParam(name = “advid”, value = “广告id”, required = true, paramType = “path”, dataType = “Long”), })
@RequestMapping(value = “/{advid}”, method = RequestMethod.GET)
public Adv detail(@PathVariable Long advid) {return this.advManager.getAdvDetail(advid);

}

}

spring cloud-Feign使用中常见问题

1. java.lang.illegalStateException : Method getChildren not annotated with HTTP method type (ex.post,get)

以下两种注解是等价的

@RequestMapping(value = “/system/regions/parent/{parent_id}”, method = RequestMethod.GET)

@GetMapping(“/regions/parent/{parent_id}”)

但是在Feign的使用中,@GetMapping(“”)是不能直接使用的,所以会出现没有指定HTTP类型的异常

2. java.lang.IllegalStateException: PathVariable annotation was empty on param 0

参数标注不能为空,问题类型同上,

public List<Regions> getChildren(@PathVariable int parent_id) {
return regionsManager.listChildren(parent_id);
}

此方法中使用了@PathVariable int parent_id,而在Feign中应该使用@PathVariable(“parent_id”) int parent_id,或@PathVariable(value=”parent_id”) int parent_id

3. Request method ‘POST’ not supported

在参数的传递中,GET方法使用@RequestParam注解,POST方法使用@RequestBody注解,若传递参数时不加注解,则默认为@RequestBody注解,即POST方法,GET方法中有参数不加@RequestParam,被调用的服务就会提示POST是不被支持的

项目调用maven classpath的两种类型

项目根据不同的运行方式,会以不同的方式调用maven classpath:

以eclipse -> run as -> spring boot 运行项目时,若项目中需要调用某个sdk,那么,eclipse会调用此sdk目录下target文件夹中的.class,字节码文件,与maven仓库中的sdk.jar无关。

而以eclipse -> run as -> maven install -> jar -> 命令行java -jar 运行项目时,项目所需依赖会被封装进jar中,而被封装进项目jar包中的sdk,则是取自maven本地仓库。

所以,若出现eclipse运行时成功,而jar包运行失败时,可以考虑重新封装sdk的jar包,替换maven本地仓库中的sdk。

nginx提示地址或端口被占用解决

今天在启动nginx 的时候遇到如下的错误

nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)

nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)

nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)

nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)

nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)

nginx: [emerg] still could not bind()

nginx也没有启动进程

[root@iZ25dgob05vZ /]# ps -ef|grep nginx

root     12150 12079  0 10:20 pts/0    00:00:00 grep nginx

kill也不能停掉进程

[root@iZ25dgob05vZ /]# killall -9 nginx

nginx: 没有进程被杀死

找了N多答案,都是说是端口被占用,但是各种解决方法无效可尝试以下操作:

1、检查80端口被什么程序占用

命令:fuser -n tcp 80

[root@iZ25dgob05vZ /]# fuser -n tcp 80

80/tcp:               7588

删除对应端口

[root@iZ25dgob05vZ /]# kill -9 7588

重新启动nginx

[root@iZ25dgob05vZ /]#  service nginx restart

Stopping nginx:                                         [FAILED]

Starting nginx:                                            [  OK  ]

JVM编码设置说明

今天服务器发现一个问题,部分中文显示正常,部分中文显示乱码。

简单访问一下,发现服务器解析中文参数没有问题,说明tomcat的编码utf-8已配置。

然后一琢磨,认为是源文件出现了编码问题。结果发现本地显示没问题,只有服务器有问题,那这下这个问题就有意思了。

经过排查,发现服务器端端catalina.sh 里少配置了 file.encoding ,导致解析出现乱码。

思考一下,发现还是有些不对, 为什么本地运行没问题,calalina.sh 配置文件中也没有配置编码,结果不乱码,服务器就乱码了呢?

 

满心欢喜的去查看服务器的默认编码,结果是 utf-8。。。

没有证明自己的预期,预期的结论是,tomcat jvm 没有设置编码,则采用系统的默认编码

由于还有很急的事情,日后再来补全这个测试。

sql server 注意事项(三)

今天在改一个bug的时候发现一条语句不兼容sql server的语句,继上两篇sql server注意事项,现补充两点。

1、上图明显看出是sql别名出问题了,原因是sql server update不支持别名,因此在写sql语句的时候要注意,在sql server环境下 update是不可以使用别名的!

2、在sql server环境下,在写查询sql语句的时候 sql之前不允许存在空格,否则会报上图错误。from 附近语法错误。例如错误语句:“ select * from es_goods”,错误语句中select之前有一个小空格,这样是错误的。正确的语句应该是“select * from es_goods”

睡前滴小idea

一.促销模块构成

营销的4P理论即为产品(Product)价格(Price)渠道(Place)促销(Promotion),促销作为营销的重要一环,承担衔接沟通企业和客户之间重要桥梁的作用。促销是电子商务网站吸引客户目光的一把利器,勾起顾客购买欲望,是给予客户心灵重重一击的一枚糖衣炮弹。

下面介绍一下常用的促销方式

(1)   折价促销

价格一直都是电子商务运行的重点,而折价促销也是电商最擅长且使用最多的促销方式。淘宝双十一,京东购物节。如此大规模的促销都是以折价的方式体现的。折价促销操作简单,效果显著。赢得了众多电商的青睐。而客户也喜欢这种直接受益的促销方式,也对他最为敏感幅度较大的折扣可以刺激客户快速消费。而且慢慢衍生出了网上折扣店这一新兴的营销方式。折价促销有很多方式去体现,例如全场两折,特定商品5折,全场2折起,等等。折价促销也有劣势,当恢复原价就无人问津了。所以才出现双十一期间订单量增加,活动过后一段订单量减少

(2)   团购——拼单式促销

团购是回报式促销的一种,他作为一种新兴的电子商务模式通过客户自行组团,专业团购网站,商家组织团购等形式,提升客户与商家的议价能力,并极大程度地进行商品让利,引起客户客户及业内厂商,甚至基本市场的关注而最常见的就是商家组织团购的形式。随着互联网的发展,团购网站在2010年如雨后春笋般的出现,走在电子商务网络够的前沿。

(3)   惠赠式促销

惠赠式也是一种回报式促销形式,包含很多种实现方式,例如买一赠一,买送礼品,买送积分,买送代金券

(4)   搭配销售

搭配销是客户在浏览一件商品时向他推荐其他商品,这件商品可以与其

他商品搭配起来一起销售同时总价格进行相应幅度的降低。配套的商品必须是客户需要的,且互相有一定的联系。搭配销售相对于其他促销方式有很多优点,一有利于扩大产品销量,二是直接降价会损伤产品价值,搭配销售让顾客觉得实惠又不会对价格进行横向比较

(5)   限时限量促销

物以稀为贵,限量促销就利用人们这个心里。

二.设计思路

电子商务王站促销通过维护老客户,吸引新客户,增加网站黏性,提升销售额和增加产品价值,在促进网站的销售和提升活力的同时,形成运营的良性循环。

  1. 业务设计原则

促销的作用体现在以下几方面。

*  吸引注意力:促销通过比较吸引人注意的方式,将产品,服务等信息传递给客户,引起他们注意。

*  说服功能:通过价格服务等方面的促销方式,说服客户消除疑虑,坚定购买。

*  刺激销售:

  1. 模式设计

下面以b2b2c电商平台团购为例,下面附上按照平台,店铺,买家三种身份在团购中不同职能来描述团购整个流程。

进程AND线程的小漫画

进程(process)和线程(thread)是操作系统的基本概念,但是它们比较抽象,不容易掌握。

最近,我读到一篇材料觉得我对进程和线程有一点领悟。

1.

计算机的核心是CPU,它承担了所有的计算任务。它就像一座工厂,时刻在运行。

2.

假定工厂的电力有限,一次只能供给一个车间使用。也就是说,一个车间开工的时候,其他车间都必须停工。背后的含义就是,单个CPU一次只能运行一个任务。

3.

进程就好比工厂的车间,它代表CPU所能处理的单个任务。任一时刻,CPU总是运行一个进程,其他进程处于非运行状态。

4.

一个车间里,可以有很多工人。他们协同完成一个任务。

5.

线程就好比车间里的工人。一个进程可以包括多个线程。

6.

车间的空间是工人们共享的,比如许多房间是每个工人都可以进出的。这象征一个进程的内存空间是共享的,每个线程都可以使用这些共享内存。

7.

可是,每间房间的大小不同,有些房间最多只能容纳一个人,比如厕所。里面有人的时候,其他人就不能进去了。这代表一个线程使用某些共享内存时,其他线程必须等它结束,才能使用这一块内存。

8.

一个防止他人进入的简单方法,就是门口加一把锁。先到的人锁上门,后到的人看到上锁,就在门口排队,等锁打开再进去。这就叫“互斥锁”(Mutual exclusion,缩写 Mutex),防止多个线程同时读写某一块内存区域。

9.

还有些房间,可以同时容纳n个人,比如厨房。也就是说,如果人数大于n,多出来的人只能在外面等着。这好比某些内存区域,只能供给固定数目的线程使用。

10.

这时的解决方法,就是在门口挂n把钥匙。进去的人就取一把钥匙,出来时再把钥匙挂回原处。后到的人发现钥匙架空了,就知道必须在门口排队等着了。这种做法叫做“信号量”(Semaphore),用来保证多个线程不会互相冲突。

不难看出,mutex是semaphore的一种特殊情况(n=1时)。也就是说,完全可以用后者替代前者。但是,因为mutex较为简单,且效率高,所以在必须保证资源独占的情况下,还是采用这种设计。

11.

操作系统的设计,因此可以归结为三点:

(1)以多进程形式,允许多个任务同时运行;

(2)以多线程形式,允许单个任务分成不同的部分运行;

(3)提供协调机制,一方面防止进程之间和线程之间产生冲突,另一方面允许进程之间和线程之间共享资源。