提交 1e91c8f0 authored 作者: Administrator's avatar Administrator

Initial commit

上级
HELP.md
target/
!.mvn/wrapper/maven-wrapper.jar
!**/src/main/**
!**/src/test/**
### STS ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### IntelliJ IDEA ###
.idea
*.iws
*.iml
*.ipr
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
### VS Code ###
.vscode/
/*
* Copyright 2007-present the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import java.net.*;
import java.io.*;
import java.nio.channels.*;
import java.util.Properties;
public class MavenWrapperDownloader {
private static final String WRAPPER_VERSION = "0.5.6";
/**
* Default URL to download the maven-wrapper.jar from, if no 'downloadUrl' is provided.
*/
private static final String DEFAULT_DOWNLOAD_URL = "https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/"
+ WRAPPER_VERSION + "/maven-wrapper-" + WRAPPER_VERSION + ".jar";
/**
* Path to the maven-wrapper.properties file, which might contain a downloadUrl property to
* use instead of the default one.
*/
private static final String MAVEN_WRAPPER_PROPERTIES_PATH =
".mvn/wrapper/maven-wrapper.properties";
/**
* Path where the maven-wrapper.jar will be saved to.
*/
private static final String MAVEN_WRAPPER_JAR_PATH =
".mvn/wrapper/maven-wrapper.jar";
/**
* Name of the property which should be used to override the default download url for the wrapper.
*/
private static final String PROPERTY_NAME_WRAPPER_URL = "wrapperUrl";
public static void main(String args[]) {
System.out.println("- Downloader started");
File baseDirectory = new File(args[0]);
System.out.println("- Using base directory: " + baseDirectory.getAbsolutePath());
// If the maven-wrapper.properties exists, read it and check if it contains a custom
// wrapperUrl parameter.
File mavenWrapperPropertyFile = new File(baseDirectory, MAVEN_WRAPPER_PROPERTIES_PATH);
String url = DEFAULT_DOWNLOAD_URL;
if(mavenWrapperPropertyFile.exists()) {
FileInputStream mavenWrapperPropertyFileInputStream = null;
try {
mavenWrapperPropertyFileInputStream = new FileInputStream(mavenWrapperPropertyFile);
Properties mavenWrapperProperties = new Properties();
mavenWrapperProperties.load(mavenWrapperPropertyFileInputStream);
url = mavenWrapperProperties.getProperty(PROPERTY_NAME_WRAPPER_URL, url);
} catch (IOException e) {
System.out.println("- ERROR loading '" + MAVEN_WRAPPER_PROPERTIES_PATH + "'");
} finally {
try {
if(mavenWrapperPropertyFileInputStream != null) {
mavenWrapperPropertyFileInputStream.close();
}
} catch (IOException e) {
// Ignore ...
}
}
}
System.out.println("- Downloading from: " + url);
File outputFile = new File(baseDirectory.getAbsolutePath(), MAVEN_WRAPPER_JAR_PATH);
if(!outputFile.getParentFile().exists()) {
if(!outputFile.getParentFile().mkdirs()) {
System.out.println(
"- ERROR creating output directory '" + outputFile.getParentFile().getAbsolutePath() + "'");
}
}
System.out.println("- Downloading to: " + outputFile.getAbsolutePath());
try {
downloadFileFromURL(url, outputFile);
System.out.println("Done");
System.exit(0);
} catch (Throwable e) {
System.out.println("- Error downloading");
e.printStackTrace();
System.exit(1);
}
}
private static void downloadFileFromURL(String urlString, File destination) throws Exception {
if (System.getenv("MVNW_USERNAME") != null && System.getenv("MVNW_PASSWORD") != null) {
String username = System.getenv("MVNW_USERNAME");
char[] password = System.getenv("MVNW_PASSWORD").toCharArray();
Authenticator.setDefault(new Authenticator() {
@Override
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
}
URL website = new URL(urlString);
ReadableByteChannel rbc;
rbc = Channels.newChannel(website.openStream());
FileOutputStream fos = new FileOutputStream(destination);
fos.getChannel().transferFrom(rbc, 0, Long.MAX_VALUE);
fos.close();
rbc.close();
}
}
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.6.3/apache-maven-3.6.3-bin.zip
wrapperUrl=https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar
Git 全局设置
```
git config --global user.name "xxx"
git config --global user.email "ddd@qq.com"
```
创建新版本库
```
git clone ssh://git@192.168.66.40:2222/loit-Infrastructure/loit-seata-order-example.git
cd loit-seata-order-example
touch README.md
git add README.md
git commit -m "add README"
git push -u origin master
```
已存在的文件夹
```
cd existing_folder
git init
git remote add origin ssh://git@192.168.66.40:2222/loit-Infrastructure/loit-seata-order-example.git
git add .
git commit -m "Initial commit"
git push -u origin master
```
已存在的 Git 版本库
```
cd existing_repo
git remote rename origin old-origin
git remote add origin ssh://git@192.168.66.40:2222/loit-Infrastructure/loit-seata-order-example.git
git push -u origin --all
git push -u origin --tags
```
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>spring-cloud-dependencies-parent</artifactId>
<groupId>org.springframework.cloud</groupId>
<version>2.0.6.RELEASE</version>
<relativePath/>
</parent>
<modelVersion>4.0.0</modelVersion>
<groupId>com.loit.project</groupId>
<artifactId>loit-seata-order-example-dependencies</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>pom</packaging>
<properties>
<!-- Maven Plugin Versions -->
<maven-compiler-plugin.version>3.7.0</maven-compiler-plugin.version>
<maven-deploy-plugin.version>2.8.2</maven-deploy-plugin.version>
<loit-seata-mybatis-mysql-suport.version>0.0.1-SNAPSHOT</loit-seata-mybatis-mysql-suport.version>
<fastjson.version>1.2.41</fastjson.version>
<swagger.version>2.9.2</swagger.version>
<swagger-annotations.version>1.5.22</swagger-annotations.version>
<swagger-models.version>1.5.22</swagger-models.version>
<modelmapper.version>1.1.0</modelmapper.version>
<spring-tuple.version>1.0.0.RELEASE</spring-tuple.version>
<loit-build-spi-common.version>1.0-SNAPSHOT</loit-build-spi-common.version>
<loit-build-web-common.version>1.0-SNAPSHOT</loit-build-web-common.version>
</properties>
<dependencyManagement>
<dependencies>
<!--Own dependencies -->
<dependency>
<groupId>com.loit.project</groupId>
<artifactId>loit-build-spi-common</artifactId>
<version>${loit-build-spi-common.version}</version>
</dependency>
<dependency>
<groupId>com.loit.project</groupId>
<artifactId>loit-build-web-common</artifactId>
<version>${loit-build-web-common.version}</version>
</dependency>
<dependency>
<groupId>com.loit.project</groupId>
<artifactId>loit-seata-mybatis-mysql-suport</artifactId>
<version>${loit-seata-mybatis-mysql-suport.version}</version>
</dependency>
<dependency>
<groupId>com.loit.project</groupId>
<artifactId>loit-seata-example-common</artifactId>
<version>${project.version}</version>
</dependency>
<!--Own dependencies - Starters -->
<!--tools-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>${fastjson.version}</version>
</dependency>
<dependency>
<groupId>org.modelmapper</groupId>
<artifactId>modelmapper</artifactId>
<version>${modelmapper.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tuple</artifactId>
<version>${spring-tuple.version}</version>
</dependency>
<!-- 集成swagger ui -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>${swagger.version}</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>${swagger.version}</version>
</dependency>
<!-- 解决Integer类型example为空时,访问swagger报错问题 -->
<dependency>
<groupId>io.swagger</groupId>
<artifactId>swagger-annotations</artifactId>
<version>${swagger-annotations.version}</version>
</dependency>
<dependency>
<groupId>io.swagger</groupId>
<artifactId>swagger-models</artifactId>
<version>${swagger-models.version}</version>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<pluginManagement>
<plugins>
</plugins>
</pluginManagement>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>${maven-compiler-plugin.version}</version>
<configuration>
<source>${java.version}</source>
<target>${java.version}</target>
<encoding>${project.build.sourceEncoding}</encoding>
<compilerVersion>${java.version}</compilerVersion>
</configuration>
</plugin>
</plugins>
</build>
<distributionManagement>
<repository>
<id>nexus-releases</id>
<name>Nexus Release Repository</name>
<url>http://39.100.254.140:12010/repository/maven-releases/</url>
</repository>
<snapshotRepository>
<id>nexus-snapshots</id>
<name>Nexus Snapshot Repository</name>
<url>http://39.100.254.140:12010/repository/maven-snapshots/</url>
</snapshotRepository>
</distributionManagement>
<repositories>
<repository>
<id>nexus-loit-dev</id>
<name>Nexus Repository</name>
<url>http://39.100.254.140:12010/repository/maven-public/</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
<releases>
<enabled>true</enabled>
</releases>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>nexus-loit-dev</id>
<name>Nexus Plugin Repository</name>
<url>http://39.100.254.140:12010/repository/maven-public/</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
<releases>
<enabled>true</enabled>
</releases>
</pluginRepository>
</pluginRepositories>
</project>
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>loit-seata-order-example</artifactId>
<groupId>com.loit.project</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>loit-seata-order-example-main</artifactId>
<packaging>jar</packaging>
<dependencies>
<dependency>
<groupId>com.loit.project</groupId>
<artifactId>loit-build-spi-common</artifactId>
</dependency>
<dependency>
<groupId>com.loit.project</groupId>
<artifactId>loit-build-web-common</artifactId>
</dependency>
<!--common-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
</dependency>
<dependency>
<groupId>org.modelmapper</groupId>
<artifactId>modelmapper</artifactId>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tuple</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--Own dependencies -->
<!-- spring cloud -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-freemarker</artifactId>
</dependency>
<!-- nacos -->
<dependency>
<groupId>com.timeloit.cloud</groupId>
<artifactId>spring-cloud-timeloit-nacos-discovery</artifactId>
</dependency>
<dependency>
<groupId>com.timeloit.cloud</groupId>
<artifactId>spring-cloud-timeloit-nacos-config</artifactId>
</dependency>
<!-- 熔断 限流-->
<dependency>
<groupId>com.timeloit.cloud</groupId>
<artifactId>spring-cloud-starter-timeloit-sentinel</artifactId>
</dependency>
<dependency>
<groupId>com.timeloit.cloud</groupId>
<artifactId>spring-cloud-timeloit-sentinel-datasource</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.csp</groupId>
<artifactId>sentinel-datasource-nacos</artifactId>
</dependency>
<!-- seata-->
<dependency>
<groupId>com.timeloit.cloud</groupId>
<artifactId>spring-cloud-timeloit-seata</artifactId>
</dependency>
<!-- mysql -->
<dependency>
<groupId>com.loit.project</groupId>
<artifactId>loit-seata-mybatis-mysql-suport</artifactId>
</dependency>
<!--swagger-->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
</dependency>
<!-- 解决Integer类型example为空时,访问swagger报错问题 -->
<dependency>
<groupId>io.swagger</groupId>
<artifactId>swagger-annotations</artifactId>
</dependency>
<dependency>
<groupId>io.swagger</groupId>
<artifactId>swagger-models</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${spring-boot.version}</version>
<configuration>
<mainClass>com.loit.seata.order.example.LoitSeataOrderExampleApplication</mainClass>
</configuration>
</plugin>
</plugins>
</build>
</project>
\ No newline at end of file
package com.loit.seata.order.example;
import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.Banner;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
@EnableDiscoveryClient
@EnableFeignClients
@SpringBootApplication(scanBasePackages = {"com.loit.seata"}, exclude = DataSourceAutoConfiguration.class)
@Slf4j
public class LoitSeataOrderExampleApplication {
public static void main(String[] args) {
log.info("start execute LoitSeataOrderExampleApplication....\n");
System.out.println("start execute LoitSeataOrderExampleApplication....\n");
new SpringApplicationBuilder(LoitSeataOrderExampleApplication.class).bannerMode(Banner.Mode.OFF).run(args);
System.out.println("end execute LoitSeataOrderExampleApplication....\n");
log.info("end execute LoitSeataOrderExampleApplication....\n");
}
}
package com.loit.seata.order.example.model;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
import lombok.experimental.Accessors;
import java.math.BigDecimal;
@Data
@Accessors(chain = true)
@TableName("order_tbl")
public class Order {
@TableId(type=IdType.AUTO)
private Integer id;
private String userId;
private String commodityCode;
private Integer count;
private BigDecimal money;
}
package com.loit.seata.order.example;
\ No newline at end of file
package com.loit.seata.order.example.repository;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.loit.seata.order.example.model.Order;
import org.apache.ibatis.annotations.Mapper;
import org.springframework.stereotype.Repository;
@Mapper
@Repository
public interface OrderDAO extends BaseMapper<Order> {
}
package com.loit.seata.order.example.service.biz;
import com.loit.seata.order.example.model.Order;
import com.loit.seata.order.example.repository.OrderDAO;
import com.loit.seata.order.example.service.comsumer.AccountFeignClient;
import com.loit.seata.order.example.service.comsumer.StorageFeignClient;
import io.seata.spring.annotation.GlobalLock;
import io.seata.spring.annotation.GlobalTransactional;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import javax.annotation.Resource;
import java.math.BigDecimal;
@Service
public class OrderService {
@Resource
private AccountFeignClient accountFeignClient;
@Resource
private StorageFeignClient storageFeignClient;
@Resource
private OrderDAO orderDAO;
/**
* 下单:创建订单、减库存,涉及到两个服务
*
* @param userId
* @param commodityCode
* @param count
*/
@GlobalTransactional
@Transactional(rollbackFor = Exception.class)
public void placeOrder(String userId, String commodityCode, Integer count) {
BigDecimal orderMoney = new BigDecimal(count).multiply(new BigDecimal(5));
Order order = new Order()
.setUserId(userId)
.setCommodityCode(commodityCode)
.setCount(count)
.setMoney(orderMoney);
orderDAO.insert(order);
storageFeignClient.deduct(commodityCode, count);
}
@Transactional(rollbackFor = Exception.class)
public void create(String userId, String commodityCode, Integer count) {
BigDecimal orderMoney = new BigDecimal(count).multiply(new BigDecimal(5));
Order order = new Order()
.setUserId(userId)
.setCommodityCode(commodityCode)
.setCount(count)
.setMoney(orderMoney);
orderDAO.insert(order);
accountFeignClient.reduce(userId, orderMoney);
}
}
package com.loit.seata.order.example.service.comsumer;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import java.math.BigDecimal;
@FeignClient(name = "account-service")
public interface AccountFeignClient {
@GetMapping("/reduce")
Boolean reduce(@RequestParam("userId") String userId, @RequestParam("money") BigDecimal money);
}
package com.loit.seata.order.example.service.comsumer;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;
@Component
@Slf4j
public class EchoServiceFallback implements StorageFeignClient{
@Override
public Boolean deduct(String commodityCode, Integer count) {
throw new RuntimeException("服务关闭了");
}
}
package com.loit.seata.order.example.service.comsumer;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
@FeignClient(name = "storage-service")
//@FeignClient(name = "storage-service", fallback = EchoServiceFallback.class)
public interface StorageFeignClient {
@GetMapping("storage/deduct")
Boolean deduct(@RequestParam("commodityCode") String commodityCode, @RequestParam("count") Integer count);
}
package com.loit.seata.order.example.web.config;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
@Configuration
@EnableSwagger2
public class SwaggerConfig {
ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title("统一用户API接口管理")
.description("统一用户API接口管理")
.version("1.0")
.build();
}
}
package com.loit.seata.order.example.web.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
import static springfox.documentation.builders.PathSelectors.regex;
@Configuration
@EnableSwagger2
public class SwaggerUumsConfig extends SwaggerConfig {
@Bean
public Docket createRestfulApi() {
return new Docket(DocumentationType.SWAGGER_2)
.groupName("order")
.apiInfo(apiInfo())
.select()
.paths(regex("/order/.*"))
.build();
}
}
package com.loit.seata.order.example.web.config;
import com.alibaba.fastjson.serializer.SerializeConfig;
import com.alibaba.fastjson.serializer.SerializerFeature;
import com.alibaba.fastjson.serializer.ToStringSerializer;
import com.alibaba.fastjson.support.config.FastJsonConfig;
import com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.modelmapper.ModelMapper;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.ObjectFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.SpringBootConfiguration;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.context.annotation.Bean;
import org.springframework.core.convert.ConversionService;
import org.springframework.http.converter.ByteArrayHttpMessageConverter;
import org.springframework.http.converter.HttpMessageConverter;
import org.springframework.http.converter.ResourceHttpMessageConverter;
import org.springframework.http.converter.StringHttpMessageConverter;
import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter;
import org.springframework.http.converter.support.AllEncompassingFormHttpMessageConverter;
import org.springframework.http.converter.xml.SourceHttpMessageConverter;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import java.math.BigInteger;
import java.util.List;
/**
* Spring Boot 配置web启动信息,
* 用于替换 web.xml
* <p>
*/
@SpringBootConfiguration
public class WebMvcConfigBean implements WebMvcConfigurer, ApplicationContextAware {
@Autowired
@Qualifier("mvcConversionService")
private ObjectFactory<ConversionService> conversionService;
@Autowired
private ObjectFactory<ObjectMapper> objectMapper;
private ApplicationContext applicationContext;
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
StringHttpMessageConverter stringConverter = new StringHttpMessageConverter();
stringConverter.setWriteAcceptCharset(false);
converters.add(new ByteArrayHttpMessageConverter());
converters.add(stringConverter);
converters.add(new ResourceHttpMessageConverter());
converters.add(new SourceHttpMessageConverter<>());
converters.add(new AllEncompassingFormHttpMessageConverter());
/**
* 集成FastJson
*/
FastJsonHttpMessageConverter fastConverter = new FastJsonHttpMessageConverter();
FastJsonConfig fastJsonConfig = new FastJsonConfig();
fastJsonConfig.setSerializerFeatures(
SerializerFeature.PrettyFormat
);
SerializeConfig serializeConfig = SerializeConfig.getGlobalInstance();
serializeConfig.put(BigInteger.class, ToStringSerializer.instance);
serializeConfig.put(Long.class, ToStringSerializer.instance);
serializeConfig.put(Long.TYPE, ToStringSerializer.instance);
fastJsonConfig.setSerializeConfig(serializeConfig);
fastJsonConfig.setDateFormat("yyyy-MM-dd");
fastConverter.setFastJsonConfig(fastJsonConfig);
converters.add(fastConverter);
}
@Override
public void extendMessageConverters(List<HttpMessageConverter<?>> converters) {
MappingJackson2HttpMessageConverter jackson2HttpMessageConverter = new MappingJackson2HttpMessageConverter(
objectMapper.getObject());
converters.add(jackson2HttpMessageConverter);
}
@Override
public void addInterceptors(InterceptorRegistry registry) {
//registry.addInterceptor(httpLogInteceptor()).addPathPatterns("/**");
//registry.addInterceptor(userInterceptor()).addPathPatterns("/**");
}
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**").allowedOrigins("*")
.allowedMethods("GET", "HEAD", "POST", "PUT", "DELETE", "OPTIONS")
.allowCredentials(false).maxAge(3600);
}
@Override
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
this.applicationContext = applicationContext;
}
/**
* Bean Utils
*/
@Bean
public ModelMapper modelMapper() {
ModelMapper modelMapper = new ModelMapper();
modelMapper.getConfiguration().setAmbiguityIgnored(true);
return modelMapper;
}
}
\ No newline at end of file
package com.loit.seata.order.example.web.controller;
import com.loit.build.spi.common.dto.BaseResponse;
import com.loit.build.spi.common.exception.BusinessException;
import com.loit.seata.order.example.service.biz.OrderService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
@RestController
@RequestMapping("order")
@RefreshScope
@Api(tags = "订单管理", value = "OrderController")
@Slf4j
public class OrderController {
@Resource
private OrderService orderService;
@Value("${user.name}")
private String userName;
@Value("${user.age}")
private int age;
@RequestMapping("/user")
public String simple() {
return "userName: " + userName + "age:" + age;
}
/**
* 下单:插入订单表、扣减库存, 成功下单
*
* @return
*/
@ApiOperation(value = "成功下单", notes = "下单:插入订单表、扣减库存, 成功下单")
@GetMapping("/placeOrder/commit")
public BaseResponse placeOrderCommit() {
try {
orderService.placeOrder("1", "product-1", 1);
} catch (Exception e) {
log.error("", e);
throw new BusinessException("下单失败,请稍后再试");
}
return BaseResponse.ofSuccess(true);
}
/**
* 下单:插入订单表、扣减库存,模拟回滚
*
* @return
*/
@ApiOperation(value = "模拟回滚", notes = "下单:插入订单表、扣减库存,模拟回滚")
@GetMapping("/placeOrder/rollback")
public BaseResponse placeOrderRollback() {
// product-2 扣库存时模拟了一个业务异常,
orderService.placeOrder("1", "product-2", 1);
return BaseResponse.ofSuccess(true);
}
@PostMapping("/placeOrder")
@ApiOperation(value = "下单(传参数)", notes = "插入订单表、扣减库存,模拟回滚, 传参数")
@ApiImplicitParams({
@ApiImplicitParam(paramType = "query", name = "userId", value = "用户ID", dataType = "String"),
@ApiImplicitParam(paramType = "query", name = "commodityCode", value = "商品code", dataType = "String"),
@ApiImplicitParam(paramType = "query", name = "count", value = "购买数量", dataType = "Integer")
})
public BaseResponse placeOrder(String userId, String commodityCode, Integer count) {
orderService.placeOrder(userId, commodityCode, count);
return BaseResponse.ofSuccess(true);
}
@GetMapping("/echo")
@ApiOperation(value = "测试接口响应")
public BaseResponse echo() {
return BaseResponse.ofSuccess(true);
}
}
package com.loit.seata.order.example.web.exception;
public class BeanUtilsException extends RuntimeException{
public BeanUtilsException(Throwable e){
super(e);
}
}
package com.loit.seata.order.example.web.exception.base;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.loit.build.spi.common.dto.BaseResponse;
import com.loit.build.spi.common.dto.ResponseStatusEnum;
import com.loit.build.spi.common.exception.BusinessException;
import com.loit.build.web.common.exception.base.ArgumentInvalidResult;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.env.Environment;
import org.springframework.http.HttpStatus;
import org.springframework.validation.FieldError;
import org.springframework.web.HttpRequestMethodNotSupportedException;
import org.springframework.web.bind.MethodArgumentNotValidException;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.ResponseStatus;
import javax.servlet.http.HttpServletRequest;
import javax.validation.ConstraintViolation;
import javax.validation.ConstraintViolationException;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import java.util.Set;
/**
* 全局异常处理
*/
@ControllerAdvice
@ResponseBody
@Slf4j
public class GlobalExceptionHandler {
@Autowired
ObjectMapper objectMapper;
private Environment env;
@ExceptionHandler(HttpRequestMethodNotSupportedException.class)
@ResponseStatus(value = HttpStatus.METHOD_NOT_ALLOWED)
public Object handleRequestMethodException(HttpServletRequest request,
HttpRequestMethodNotSupportedException exception) {
log.error(exception.getMessage(), exception);
BaseResponse baseResponse = new BaseResponse();
baseResponse.setCode(HttpStatus.METHOD_NOT_ALLOWED.getReasonPhrase());
baseResponse.setMessage(exception.getMessage());
baseResponse.setData("HttpRequestMethodNotSupported Exception");
return baseResponse;
}
@ExceptionHandler(MethodArgumentNotValidException.class)
@ResponseStatus(value = HttpStatus.INTERNAL_SERVER_ERROR)
public Object methodArgumentNotValidHandler(MethodArgumentNotValidException exception) throws JsonProcessingException {
List<ArgumentInvalidResult> argumentInvalidResults = new ArrayList<ArgumentInvalidResult>();
for (FieldError error : exception.getBindingResult().getFieldErrors()) {
ArgumentInvalidResult argumentInvalidResult = new ArgumentInvalidResult();
argumentInvalidResult.setField(error.getField());
argumentInvalidResult.setRejectedValue(error.getRejectedValue());
argumentInvalidResult.setDefaultMessage(error.getDefaultMessage());
argumentInvalidResults.add(argumentInvalidResult);
}
log.error(" 方法参数无效错误: message:{}, parameter: {}, result:{}",
exception.getMessage(),
objectMapper.writeValueAsString(exception.getParameter()),
objectMapper.writeValueAsString(exception.getBindingResult())
);
BaseResponse baseResponse = new BaseResponse();
baseResponse.setCode(ResponseStatusEnum.PARAMETER_ERROR.getCode());
baseResponse.setMessage(env.getProperty(ResponseStatusEnum.PARAMETER_ERROR.getCode(), ResponseStatusEnum.PARAMETER_ERROR.getMessage()));
baseResponse.setData(argumentInvalidResults);
return baseResponse;
}
@ExceptionHandler(BusinessException.class)
@ResponseStatus(value = HttpStatus.INTERNAL_SERVER_ERROR)
public Object businessExceptionHandler(BusinessException exception) {
log.error(exception.getMessage(), exception);
BaseResponse baseResponse = new BaseResponse();
baseResponse.setCode(exception.getCode());
baseResponse.setMessage(exception.getMessage());
baseResponse.setData(exception.toString());
return baseResponse;
}
@ExceptionHandler(SQLException.class)
@ResponseStatus(value = HttpStatus.INTERNAL_SERVER_ERROR)
public Object handleSQLException(HttpServletRequest request,
SQLException exception) {
log.error(exception.getMessage(), exception);
BaseResponse baseResponse = new BaseResponse();
baseResponse.setCode(HttpStatus.INTERNAL_SERVER_ERROR.getReasonPhrase());
baseResponse.setMessage(exception.getMessage());
baseResponse.setData("SQLQuery Error");
return baseResponse;
}
@ExceptionHandler(ConstraintViolationException.class)
@ResponseStatus(value = HttpStatus.INTERNAL_SERVER_ERROR)
public Object handleConstraintViolationException(HttpServletRequest request,
ConstraintViolationException exception) {
BaseResponse baseResponse = new BaseResponse();
baseResponse.setCode(HttpStatus.INTERNAL_SERVER_ERROR.getReasonPhrase());
Set<ConstraintViolation<?>> violations = exception.getConstraintViolations();
StringBuffer errorMsg = new StringBuffer();
for (ConstraintViolation<?> item : violations) {
errorMsg.append(item.getMessage());
}
baseResponse.setMessage(errorMsg.toString());
log.error(errorMsg.toString());
baseResponse.setData("参数校验异常 Error");
return baseResponse;
}
@ExceptionHandler(RuntimeException.class)
@ResponseStatus(value = HttpStatus.INTERNAL_SERVER_ERROR)
public Object handleAllException(HttpServletRequest request,
RuntimeException exception) {
log.error(exception.getMessage(), exception);
BaseResponse baseResponse = new BaseResponse();
baseResponse.setCode(HttpStatus.INTERNAL_SERVER_ERROR.getReasonPhrase());
baseResponse.setMessage(exception.getMessage());
baseResponse.setData("Runtime Error");
return baseResponse;
}
@ExceptionHandler(Exception.class)
@ResponseStatus(value = HttpStatus.INTERNAL_SERVER_ERROR)
public Object handleAllException(HttpServletRequest request,
Exception exception) {
log.error(exception.getMessage(), exception);
BaseResponse baseResponse = new BaseResponse();
baseResponse.setCode(HttpStatus.INTERNAL_SERVER_ERROR.getReasonPhrase());
baseResponse.setMessage(exception.getMessage());
baseResponse.setData("Error");
return baseResponse;
}
}
package com.loit.seata.order.example.web;
\ No newline at end of file
package com.loit.seata.order.example.web.utils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.lang.reflect.Field;
import java.util.Collection;
import java.util.Map;
/**
* 于page配合 填充数据
*
* @Title: BulkMapper
*/
public abstract class BulkMapper<T> {
//private static final String PRE_NAME = "Name";
private static final Logger logger = LoggerFactory.getLogger(BulkMapper.class);
public abstract void mapBulk(T entity, Map<String, Object> paramMap, Map<String, Object> requestMap);
/*
* 加载 延时加载的collection 数据
*/
public void loadCollectionInfo(Object entity, Map<String, Object> paramMap) {
try {
Field[] fields = entity.getClass().getDeclaredFields();
for (Field field : fields) {
field.setAccessible(true);
if (Collection.class.isAssignableFrom(field.getType())) {
paramMap.put(field.getName(), field.get(entity));
}
}
} catch (Exception e) {
logger.error(e.getMessage(), e);
}
}
/*public void loadIndexInfo(Object entity, Map<String, Object> paramMap, boolean isNeedSetInfo) {
try {
String tableName = entity.getClass().getSimpleName();
Field[] fields = entity.getClass().getDeclaredFields();
for (Field field : fields) {
field.setAccessible(true);
if (Collection.class.isAssignableFrom(field.getType())) {
buildSetInfo(entity, paramMap, isNeedSetInfo, field);
} else {
buildCodeName(entity, paramMap, tableName, field);
}
}
} catch (Exception e) {
logger.error(e.getMessage(), e);
}
}
private void buildCodeName(Object entity, Map<String, Object> paramMap, String tableName, Field field) throws IllegalAccessException {
DataDictService dataDictService = (DataDictService) SpringUtils.getBean("dataDictServiceImpl");
Object value = field.get(entity);
if (value == null) {
return;
}
ZtreeDictNote dataDict = dataDictService.findByFieldInfo(tableName, field.getName(), String.valueOf(value));
if (dataDict == null) {
return;
}
String codeName = dataDict.getCodeName();
if (!StringUtil.isEmpty(codeName)) {
paramMap.put(field.getName() + PRE_NAME, codeName);
}
}
@SuppressWarnings("rawtypes")
private void buildSetInfo(Object entity, Map<String, Object> paramMap, boolean isNeedSetInfo, Field field) throws IllegalAccessException {
if (!isNeedSetInfo) {
return;
}
Collection collection = (Collection) field.get(entity);
if (collection == null || collection.isEmpty()) {
return;
}
for (Object info : collection) {
if (info == null) {
continue;
}
Map<String, Object> setInfoMap = FastjsonUtils.toMap(info);
paramMap.put(field.getName(), setInfoMap);
}
}*/
}
\ No newline at end of file
package com.loit.seata.order.example.web.utils;
import com.fasterxml.jackson.core.JsonGenerationException;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.JavaType;
import com.fasterxml.jackson.databind.JsonMappingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.util.Assert;
import java.io.IOException;
import java.io.Writer;
import java.text.SimpleDateFormat;
import java.util.Map;
import java.util.TimeZone;
/**
* Utils - JSON
*
*/
public final class FastjsonUtils {
private static final Logger logger = LoggerFactory.getLogger(FastjsonUtils.class);
/** ObjectMapper */
private static ObjectMapper mapper = new ObjectMapper();
/**
* 不可实例化
*/
private FastjsonUtils() {
}
/**
* 将对象转换为JSON字符串
*
* @param value
* 对象
* @return JSOn字符串
*/
public static String toJson(Object value) {
try {
mapper.setTimeZone(TimeZone.getTimeZone("GMT+08"));
mapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd"));
return mapper.writeValueAsString(value);
} catch (Exception e) {
logger.error(e.getMessage(), e);
}
return null;
}
/**
* 将对象转换为Map字符串
*
* @param value
* 对象
* @return JSOn字符串
*/
@SuppressWarnings("unchecked")
public static Map<String, Object> toMap(Object value) {
try {
String json = mapper.writeValueAsString(value);
return mapper.readValue(json, Map.class);
} catch (Exception e) {
logger.error(e.getMessage(), e);
}
return null;
}
@SuppressWarnings("unchecked")
public static Map<String, Object> jsonToMap(String json) {
try {
return mapper.readValue(json, Map.class);
} catch (Exception e) {
logger.error(e.getMessage(), e);
}
return null;
}
/**
* 将JSON字符串转换为对象
*
* @param json
* JSON字符串
* @param valueType
* 对象类型
* @return 对象
*/
public static <T> T toObject(String json, Class<T> valueType) {
Assert.hasText(json);
Assert.notNull(valueType);
try {
return mapper.readValue(json, valueType);
} catch (Exception e) {
logger.error(e.getMessage(), e);
}
return null;
}
/**
* 将JSON字符串转换为对象
*
* @param json
* JSON字符串
* @param typeReference
* 对象类型
* @return 对象
*/
public static <T> T toObject(String json, TypeReference<?> typeReference) {
Assert.hasText(json);
Assert.notNull(typeReference);
try {
return mapper.readValue(json, typeReference);
} catch (Exception e) {
logger.error(e.getMessage(), e);
}
return null;
}
/**
* 将JSON字符串转换为对象
*
* @param json
* JSON字符串
* @param javaType
* 对象类型
* @return 对象
*/
public static <T> T toObject(String json, JavaType javaType) {
Assert.hasText(json);
Assert.notNull(javaType);
try {
return mapper.readValue(json, javaType);
} catch (Exception e) {
logger.error(e.getMessage(), e);
}
return null;
}
/**
* 将对象转换为JSON流
*
* @param writer
* writer
* @param value
* 对象
*/
public static void writeValue(Writer writer, Object value) {
try {
mapper.writeValue(writer, value);
} catch (JsonGenerationException e) {
logger.error(e.getMessage(), e);
} catch (JsonMappingException e) {
logger.error(e.getMessage(), e);
} catch (IOException e) {
logger.error(e.getMessage(), e);
}
}
/**
* 将Json格式字符串转换成Java对象
*
* @param jsonString
* Json格式字符串
* @param beanClass
* Java对象Class
* @param classMap
* 包含的对象集合中的Java对象Class
* @return Object
*/
/*public static Object jsonToBean(String jsonString, Class beanClass, Map classMap) {
JSONObject jsonObject = null;
try {
jsonObject = JSONObject.fromObject(jsonString);
} catch (Exception e) {
e.printStackTrace();
}
return JSONObject.toBean(jsonObject, beanClass, classMap);
}
public static Map jsonToMap(String jsonString) {
JSONObject jsonObject = JSONObject.fromObject(jsonString);
Map map = new HashMap();
for (Iterator iter = jsonObject.keys(); iter.hasNext();) {
String key = (String) iter.next();
map.put(key, jsonObject.get(key));
}
return map;
}*/
}
\ No newline at end of file
package com.loit.seata.order.example.web.utils;
import java.io.File;
import java.io.FileWriter;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
public class GenEntityMySql {
private static final GenEntityMySql INSTANCE = new GenEntityMySql();
private String tableName;// 表名
private String[] colNames; // 列名数组
private String[] colTypes; // 列名类型数组
private int[] colSizes; // 列名大小数组
private boolean needUtil = false; // 是否需要导入包java.util.*
private boolean needSql = false; // 是否需要导入包java.sql.*
private static final SimpleDateFormat SDF = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
private static final String SQL = "SELECT * FROM ";// 数据库操作
// TODO 需要修改的地方
private static final String URL = "jdbc:mysql://192.168.111.118:3306/jycj?serverTimezone=UTC";
private static final String NAME = "root";
private static final String PASS = "jycj@123456";
private static final String DRIVER = "com.mysql.cj.jdbc.Driver";
private String packageOutPath = "D://temp/entity";// 指定实体生成所在包的路径
private String authorName = "ljl";// 作者名字
private String[] generateTables = null;//指定需要生成的表的表名,全部生成设置为null
/**
* 类的构造方法
*/
private GenEntityMySql() {
}
/**
* @return
* @description 生成class的所有内容
* @author paul
* @date 2017年8月18日 下午5:30:07
* @update 2017年8月18日 下午5:30:07
* @version V1.0
*/
private String parse() {
StringBuffer sb = new StringBuffer();
sb.append("package " + packageOutPath + ";\r\n");
sb.append("\r\n");
// 判断是否导入工具包
if (needUtil) {
sb.append("import java.util.Date;\r\n");
}
if (needSql) {
sb.append("import java.sql.*;\r\n");
}
sb.append("import javax.persistence.Entity;\r\n");
sb.append("import javax.persistence.Table;\r\n");
// 注释部分
sb.append("/**\r\n");
sb.append(" * table name: " + tableName + "\r\n");
sb.append(" * author name: " + authorName + "\r\n");
sb.append(" * create time: " + SDF.format(new Date()) + "\r\n");
sb.append(" */ \r\n");
sb.append("@Entity" + "\r\n");
sb.append("@Table(name = " + "\"" + tableName.toUpperCase() + "\")" + "\r\n");
// 实体部分
sb.append("public class " + getTransStr(tableName, true) + "{\r\n\r\n");
processAllAttrs(sb);// 属性
sb.append("\r\n");
processAllMethod(sb);// get set方法
sb.append("}\r\n");
return sb.toString();
}
/**
* @param sb
* @description 生成所有成员变量
* @author paul
* @date 2017年8月18日 下午5:15:04
* @update 2017年8月18日 下午5:15:04
* @version V1.0
*/
private void processAllAttrs(StringBuffer sb) {
for (int i = 0; i < colNames.length; i++) {
sb.append("\tprivate " + sqlType2JavaType(colTypes[i]) + " " + getTransStr(colNames[i], false) + ";\r\n");
}
}
/**
* @param sb
* @description 生成所有get/set方法
* @author paul
* @date 2017年8月18日 下午5:14:47
* @update 2017年8月18日 下午5:14:47
* @version V1.0
*/
private void processAllMethod(StringBuffer sb) {
for (int i = 0; i < colNames.length; i++) {
sb.append("\tpublic void set" + getTransStr(colNames[i], true) + "(" + sqlType2JavaType(colTypes[i]) + " "
+ getTransStr(colNames[i], false) + "){\r\n");
sb.append("\t\tthis." + getTransStr(colNames[i], false) + "=" + getTransStr(colNames[i], false) + ";\r\n");
sb.append("\t}\r\n");
sb.append("\tpublic " + sqlType2JavaType(colTypes[i]) + " get" + getTransStr(colNames[i], true) + "(){\r\n");
sb.append("\t\treturn " + getTransStr(colNames[i], false) + ";\r\n");
sb.append("\t}\r\n");
}
}
/**
* @param str 传入字符串
* @return
* @description 将传入字符串的首字母转成大写
* @author paul
* @date 2017年8月18日 下午5:12:12
* @update 2017年8月18日 下午5:12:12
* @version V1.0
*/
private String initCap(String str) {
char[] ch = str.toCharArray();
if (ch[0] >= 'a' && ch[0] <= 'z')
ch[0] = (char) (ch[0] - 32);
return new String(ch);
}
/**
* @return
* @description 将mysql中表名和字段名转换成驼峰形式
* @author paul
* @date 2017年8月18日 下午4:55:07
* @update 2017年8月18日 下午4:55:07
* @version V1.0
*/
private String getTransStr(String before, boolean firstChar2Upper) {
//不带"_"的字符串,则直接首字母大写后返回
if (!before.contains("_"))
return firstChar2Upper ? initCap(before) : before;
String[] strs = before.split("_");
StringBuffer after = null;
if (firstChar2Upper) {
after = new StringBuffer(initCap(strs[0]));
} else {
after = new StringBuffer(strs[0]);
}
if (strs.length > 1) {
for (int i = 1; i < strs.length; i++)
after.append(initCap(strs[i]));
}
return after.toString();
}
/**
* @return
* @description 查找sql字段类型所对应的Java类型
* @author paul
* @date 2017年8月18日 下午4:55:41
* @update 2017年8月18日 下午4:55:41
* @version V1.0
*/
private String sqlType2JavaType(String sqlType) {
if (sqlType.equalsIgnoreCase("bit")) {
return "boolean";
} else if (sqlType.equalsIgnoreCase("tinyint")) {
return "byte";
} else if (sqlType.equalsIgnoreCase("smallint")) {
return "short";
} else if (sqlType.equalsIgnoreCase("int")) {
return "Integer";
} else if (sqlType.equalsIgnoreCase("bigint")) {
return "Long";
} else if (sqlType.equalsIgnoreCase("float")) {
return "float";
} else if (sqlType.equalsIgnoreCase("decimal")) {
return "BigDecimal";
} else if (sqlType.equalsIgnoreCase("numeric")
|| sqlType.equalsIgnoreCase("real") || sqlType.equalsIgnoreCase("money")
|| sqlType.equalsIgnoreCase("smallmoney")) {
return "double";
} else if (sqlType.equalsIgnoreCase("varchar") || sqlType.equalsIgnoreCase("char")
|| sqlType.equalsIgnoreCase("nvarchar") || sqlType.equalsIgnoreCase("nchar")
|| sqlType.equalsIgnoreCase("text")) {
return "String";
} else if (sqlType.equalsIgnoreCase("datetime") || sqlType.equalsIgnoreCase("date")) {
return "Date";
} else if (sqlType.equalsIgnoreCase("image")) {
return "Blod";
}
return null;
}
/**
* @throws Exception
* @description 生成方法
* @author paul
* @date 2017年8月18日 下午2:04:20
* @update 2017年8月18日 下午2:04:20
* @version V1.0
*/
private void generate() throws Exception {
//与数据库的连接
Connection con;
PreparedStatement pStemt = null;
Class.forName(DRIVER);
con = DriverManager.getConnection(URL, NAME, PASS);
System.out.println("connect database success...");
//获取数据库的元数据
DatabaseMetaData db = con.getMetaData();
//是否有指定生成表,有指定则直接用指定表,没有则全表生成
List<String> tableNames = new ArrayList<>();
if (generateTables == null) {
//从元数据中获取到所有的表名
ResultSet rs = db.getTables("jycj", null, null, new String[]{"TABLE"});
while (rs.next()) tableNames.add(rs.getString(3));
} else {
for (String tableName : generateTables) tableNames.add(tableName);
}
String tableSql;
PrintWriter pw = null;
for (int j = 0; j < tableNames.size(); j++) {
tableName = tableNames.get(j);
tableSql = SQL + tableName;
pStemt = con.prepareStatement(tableSql);
ResultSetMetaData rsmd = pStemt.getMetaData();
int size = rsmd.getColumnCount();
colNames = new String[size];
colTypes = new String[size];
colSizes = new int[size];
//获取所需的信息
for (int i = 0; i < size; i++) {
colNames[i] = rsmd.getColumnName(i + 1);
colTypes[i] = rsmd.getColumnTypeName(i + 1);
if (colTypes[i].equalsIgnoreCase("datetime"))
needUtil = true;
if (colTypes[i].equalsIgnoreCase("image") || colTypes[i].equalsIgnoreCase("text"))
needSql = true;
colSizes[i] = rsmd.getColumnDisplaySize(i + 1);
}
//解析生成class的所有内容
String content = parse();
//输出生成文件
File directory = new File("");
String dirName = packageOutPath.replace(".", "/");
File dir = new File(dirName);
if (!dir.exists() && dir.mkdirs()) System.out.println("generate dir 【" + dirName + "】");
String javaPath = dirName + "/" + getTransStr(tableName, true) + ".java";
FileWriter fw = new FileWriter(javaPath);
pw = new PrintWriter(fw);
pw.println(content);
pw.flush();
System.out.println("create class 【" + tableName + "】");
}
if (pw != null)
pw.close();
}
/**
* @param args
* @description 执行方法
* @author paul
* @date 2017年8月18日 下午2:03:35
* @update 2017年8月18日 下午2:03:35
* @version V1.0
*/
public static void main(String[] args) {
try {
INSTANCE.generate();
System.out.println("generate classes success!");
} catch (Exception e) {
e.printStackTrace();
}
}
}
package com.loit.seata.order.example.web.utils;
import lombok.extern.slf4j.Slf4j;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.util.Collection;
import java.util.Enumeration;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
* Http 工具类
* 用于对HttpServletRequest或HttpServletResponse进行操作
* Created by zhangzhiyi on 2018/3/8.
*/
@Slf4j
public class HttpUtil {
private static final Pattern PATTERN_HEADER = Pattern.compile("(^|-)([a-zA-Z])([a-zA-Z]*)");
/**
* 转换 Http 请求头 或 响应头
* @param headerName
* @return
*/
public static String convertHeaderName(String headerName) {
Matcher matcher = PATTERN_HEADER.matcher(headerName);
StringBuffer sb = new StringBuffer();
while (matcher.find()) {
matcher.appendReplacement(sb,
matcher.group(1) + matcher.group(2).toUpperCase() + matcher.group(3).toLowerCase());
}
matcher.appendTail(sb);
return sb.toString();
}
/**
* 打印请求参数
*
* @param request
*/
public static void printRequestParameter(HttpServletRequest request) {
request.getParameterMap().forEach((k, v) ->
log.info(" {}=\"{}\"",
k,
request.getParameter(k)
)
);
}
/**
* 打印请求头
*
* @param request
*/
public static void printRequestHeader(HttpServletRequest request) {
Enumeration<String> headerNames = request.getHeaderNames();
while (headerNames.hasMoreElements()) {
String key = headerNames.nextElement();
log.info(" {}: \"{}\"",
convertHeaderName(key),
request.getHeader(key)
);
}
}
/**
* 打印响应头
*
* @param response
*/
public static void printResponseHeader(HttpServletResponse response) {
Collection<String> headerNames = response.getHeaderNames();
headerNames.forEach(key ->
log.info(" {}: \"{}\"",
convertHeaderName(key),
response.getHeader(key)
)
);
}
/**
* 打印cookie
*
* @param request
*/
public static void printRequestCookie(HttpServletRequest request) {
Cookie[] cookies = request.getCookies();
if (null == cookies) {
return;
}
for (Cookie cookie : cookies) {
try {
log.info(" {Domain:{}, Path:{}, Name:{}, Value:{}, MaxAge:{}, Comment:{}, Version:{}, Secure:{}}",
cookie.getDomain(),
cookie.getPath(),
cookie.getName(),
null != cookie.getValue()
? URLDecoder.decode(cookie.getValue(), "UTF-8")
: null,
cookie.getMaxAge(),
cookie.getComment(),
cookie.getVersion(),
cookie.getSecure()
);
} catch (UnsupportedEncodingException e) {
log.error("不支持的编码", e);
}
}
}
}
package com.loit.seata.order.example.web.utils;
import org.springframework.context.MessageSource;
public class MessageUtils {
private static MessageSource messageSource;
/**
* 根据消息键和参数 获取消息
* 委托给spring messageSource
*
* @param code 消息键
* @param args 参数
* @return msg
*/
public static String message(String code, Object... args) {
if (messageSource == null) {
messageSource = SpringUtils.getBean(MessageSource.class);
}
return messageSource.getMessage(code, args, null);
}
}
package com.loit.seata.order.example.web.utils;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
public class MulBulkMapperConverter<T> {
/**
* @Title: 将resultList 里面的 entity 转换为对应的map<String, String>
*/
/*public void convertResultToMap(Page<T> page, BulkMapper<T> bulkMapper) {
// 1. 清除
page.getResultMapList().clear();
ParamRequest pageRequest = page.getPageRequest();
List<T> resultList = page.getResult();
if (resultList != null && !resultList.isEmpty()) {
for (T entity : resultList) {
Map<String, Object> objectMap = FastjsonUtils.toMap(entity);
// 3.附加属性
if (bulkMapper != null && entity != null) {
if (pageRequest == null) {
bulkMapper.mapBulk(entity, objectMap, null);
} else {
bulkMapper.mapBulk(entity, objectMap, pageRequest.getRequestMap());
}
}
page.getResultMapList().add(objectMap);
}
}
}*/
/**
*
* @Title: convertMulResultToMap
* @Description: (将resultList 里面的 entity 转换为对应的Map<String, Object>)
* @param bulkMapper
* @param userId
* 如果userId = null,则查询当前登录用户ID
* @return void 返回类型
* @throws
* @author Administrator
*/
/*@SuppressWarnings({ "rawtypes", "unchecked" })
public void convertMulResultToMap(Page<T> page, MulBulkMapper bulkMapper, Integer userId) {
// 1. 清除
page.getResultMapList().clear();
Iterator iterator = page.getResult().iterator();
ParamRequest pageRequest = page.getPageRequest();
// hql join 查询 返回 多个对象
while (iterator.hasNext()) {
Object object = iterator.next();
Object[] entitys = null;
T mainEntity = null;
if (object instanceof Object[]) {
entitys = (Object[]) object;
mainEntity = (T) entitys[0];
} else {
mainEntity = (T) object;
entitys = new Object[] { object };
}
Map<String, Object> objectMap = FastjsonUtils.toMap(mainEntity);
// 3.附加属性
if (bulkMapper != null && mainEntity != null) {
if (pageRequest == null) {
bulkMapper.mapBulk(entitys, objectMap, null, userId);
} else {
bulkMapper.mapBulk(entitys, objectMap, pageRequest.getRequestMap(), userId);
}
}
page.getResultMapList().add(objectMap);
}
}*/
/**
*
* @Title: convertMulResultToMap
* @Description: (将resultList 里面的 entity 转换为对应的List<Map<String, Object>>)
* @param bulkMapper
* @param resultList
* @param userId
* 如果userId = null,则查询当前登录用户ID
* @return void 返回类型
* @throws
* @author Administrator
*/
/*@SuppressWarnings({ "rawtypes", "unchecked" })
public List<Map<String, Object>> convertMulResultToMap(MulBulkMapper bulkMapper, List<T> resultList, Integer userId) {
// 1. 清除
List<Map<String, Object>> resultMapList = new ArrayList<Map<String, Object>>();
Iterator iterator = resultList.iterator();
// hql join 查询 返回 多个对象
while (iterator.hasNext()) {
Object object = iterator.next();
Object[] entitys = null;
T mainEntity = null;
if (object instanceof Object[]) {
entitys = (Object[]) object;
mainEntity = ((T) entitys[0]);
} else {
mainEntity = (T) object;
entitys = new Object[] { object };
}
Map<String, Object> objectMap = FastjsonUtils.toMap(mainEntity);
// 3.附加属性
if (bulkMapper != null && mainEntity != null) {
bulkMapper.mapBulk(entitys, objectMap, null, null);
}
resultMapList.add(objectMap);
}
return resultMapList;
}*/
/**
* @Title: 将list<T> 里面的 entity 转换为对应的map<String, String> 返回
*/
public List<Map<String, Object>> convertListResultToMap(BulkMapper<T> bulkMapper, List<T> resultList) {
List<Map<String, Object>> resultMapList = new ArrayList<Map<String, Object>>();
if (resultList != null && !resultList.isEmpty()) {
for (T result : resultList) {
// 2.先将基本属性 转换为map
Map<String, Object> objectMap = FastjsonUtils.toMap(result);
// 3.附加属性
if (bulkMapper != null || result == null) {
bulkMapper.mapBulk(result, objectMap, null);
}
resultMapList.add(objectMap);
}
}
return resultMapList;
}
}
\ No newline at end of file
package com.loit.seata.order.example.web.utils;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.NoSuchBeanDefinitionException;
import org.springframework.beans.factory.config.BeanFactoryPostProcessor;
import org.springframework.beans.factory.config.ConfigurableListableBeanFactory;
public final class SpringUtils implements BeanFactoryPostProcessor {
private static ConfigurableListableBeanFactory beanFactory; // Spring应用上下文环境
@Override
public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
SpringUtils.beanFactory = beanFactory;
}
/**
* 获取对象
*
* @param name
* @return Object 一个以所给名字注册的bean的实例
* @throws BeansException
*
*/
@SuppressWarnings("unchecked")
public static <T> T getBean(String name) throws BeansException {
return (T) beanFactory.getBean(name);
}
/**
* 获取类型为requiredType的对象
*
* @param clz
* @return
* @throws BeansException
*
*/
public static <T> T getBean(Class<T> clz) throws BeansException {
T result = (T) beanFactory.getBean(clz);
return result;
}
/**
* 如果BeanFactory包含一个与所给名称匹配的bean定义,则返回true
*
* @param name
* @return boolean
*/
public static boolean containsBean(String name) {
return beanFactory.containsBean(name);
}
/**
* 判断以给定名字注册的bean定义是一个singleton还是一个prototype。 如果与给定名字相应的bean定义没有被找到,将会抛出一个异常(NoSuchBeanDefinitionException)
*
* @param name
* @return boolean
* @throws NoSuchBeanDefinitionException
*
*/
public static boolean isSingleton(String name) throws NoSuchBeanDefinitionException {
return beanFactory.isSingleton(name);
}
/**
* @param name
* @return Class 注册对象的类型
* @throws NoSuchBeanDefinitionException
*
*/
public static Class<?> getType(String name) throws NoSuchBeanDefinitionException {
return beanFactory.getType(name);
}
/**
* 如果给定的bean名字在bean定义中有别名,则返回这些别名
*
* @param name
* @return
* @throws NoSuchBeanDefinitionException
*
*/
public static String[] getAliases(String name) throws NoSuchBeanDefinitionException {
return beanFactory.getAliases(name);
}
}
package com.loit.seata.order.example.web.utils;
import org.apache.commons.lang3.StringUtils;
import java.util.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
* <p>
* Title:
* </p>
* <p>
* Description:
* </p>
* <p>
* Copyright: Copyright (c) 2009
* </p>
* <p>
* Company: RongJi
* </p>
*
* @author Anna
* @version 2.0
* @create in 2009-3-13
*/
public final class StringUtil {
/**
* 验证字符串是否为空
*
* @param string
* @return
*/
public static boolean isEmpty(String string) {
boolean result = false;
if (string == null || "".equals(string.trim())) {
result = true;
}
return result;
}
/**
* @param num
* @return String 返回类型
* @throws
* @Title: getSpaces
* @Description: 获取固定个数的空格
* @author Administrator
*/
public static String getSpaces(int num) {
StringBuffer buffer = new StringBuffer("");
for (int i = 0; i < num; i++) {
buffer.append(" ");
}
return buffer.toString();
}
/**
* @param str
* @return int 返回类型
* @throws
* @Title: GetPlaceHolderLength
* @Description: 获得字符串在展示时实际的相对占位的长度值
* @author Administrator
*/
public static int GetPlaceHolderLength(String str) {
int realLength = 0;
if (str == null) {
return 0;
}
for (int i = 0; i < str.length(); i++) {
char charCode = str.charAt(i);
if (charCode >= 0 && charCode <= 128) {
realLength += 1;
} else {
realLength += 2;
}
}
return realLength;
}
/**
* 验证字符串是否为非空
*
* @param string
* @return
*/
public static boolean isNotEmpty(String string) {
boolean result = false;
if (string != null && !"".equals(string.trim())) {
result = true;
}
return result;
}
/**
* 验证字符串内容
*
* @param string 待验证字符
* @param equ_str 用于验证的内容字符(可传数组[],)
* @return
*/
public static boolean isEquals(String string, String... equ_str) {
// if(!isEmpty(string)&&!isEmpty(equ_str)){
// if(string.equals(equ_str))return true;
// }
// return false;
if (!isEmpty(string) && !isEmpty(equ_str)) {
for (String equ : equ_str) {
if (!isEmpty(equ)) {
if (string.equals(equ))
return true;
}
}
}
return false;
}
/**
* 验证字符串内容是否以...开始
*
* @param string 待验证字符
* @param star_str 用于验证的开始字符(可传数组[],)
* @return
*/
public static boolean startsWith(String string, String... star_str) {
if (!isEmpty(string) && !isEmpty(star_str)) {
for (String st : star_str) {
if (!isEmpty(st)) {
if (string.startsWith(st))
return true;
}
}
}
return false;
}
/**
* 验证字符串内容是否以...结束
*
* @param string 待验证字符
* @param end_str 用于验证的结束字符(可传数组[],)
* @return
*/
public static boolean endsWith(String string, String... end_str) {
if (!isEmpty(string) && !isEmpty(end_str)) {
for (String end : end_str) {
if (!isEmpty(end)) {
if (string.endsWith(end))
return true;
}
}
}
return false;
}
/**
* 将数字字符串转化为int型
*
* @param srcInt
* @return int
*/
public static int doNullInt(String srcInt) {
if (srcInt == null || "".equals(srcInt))
return 0;
return Integer.parseInt(srcInt);
}
public static int doNullInt(Object obj) {
String srcInt = doNullStr(obj);
if (srcInt == null || "".equals(srcInt))
return 0;
return Integer.parseInt(srcInt);
}
/**
* 将数字字符串转化为long型
*
* @param srcInt
* @return
*/
public static long doNullLong(String srcInt) {
if (srcInt == null || "".equals(srcInt))
return 0;
return Long.parseLong(srcInt);
}
public static long doNullLong(Object obj) {
String srcInt = doNullStr(obj);
if (srcInt == null || "".equals(srcInt))
return 0;
return Long.parseLong(srcInt);
}
/**
* 转化为字符串
*
* @param obj Object
* @return String
*/
public static String doNullStr(Object obj) {
String str = "";
if (obj != null) {
str = String.valueOf(obj);
if (str.equals("null")) {
str = "";
}
}
return str;
}
public static Integer doNullInteger(Object obj) {
String str = doNullStr(obj);
if (isEmpty(str)) {
str = "0";
} else {
int i = str.indexOf(".");
if (i > 0) {
str = str.substring(0, i);
}
}
return Integer.valueOf(str);
}
/**
* 验证字符串数组是否为空
*
* @param string
* @return
*/
public static boolean isEmpty(String[] string) {
boolean result = (string == null || string.length == 0) ? true : false;
if (!result) {
for (String s : string) {
if (!isEmpty(s)) {
return false;
}
}
result = true;
}
return result;
}
/**
* 对字符串进行操作,对于小于指定长度的字符,在其右方按特定字符进行补足。
* <p>
* <pre>
* 示例:
* String stringUtils = &quot;abc&quot;;
* System.out.println(StringUtils.padRight(stringUtils, 5, '0'));
* 输出结果为:abc00;
* </pre>
*
* @param value 输入值
* @param totalWidth 总长度
* @param paddingChar 不足时填充的字符
* @return 重新计算后的字符。
*/
public static String padRight(String value, int totalWidth, char paddingChar) {
String temp = value;
if (value.length() > totalWidth) {
return value;
} else {
while (temp.length() < totalWidth) {
temp = temp + paddingChar;
}
return temp;
}
}
/**
* 对字符串进行操作,对于小于指定长度的字符,在其左方按特定字符进行补足。 示例:
* <p>
* <pre>
* String stringUtils = &quot;abc&quot;;
* System.out.println(StringUtils.padLeft(stringUtils, 5, '0'));
* </pre>
* <p>
* 输出结果为:00abc;
*
* @param value 输入值
* @param totalWidth 总长度
* @param paddingChar 不足时填充的字符
* @return 重新计算后的字符。
*/
public static String padLeft(String value, int totalWidth, char paddingChar) {
String temp = value;
if (value.length() > totalWidth) {
return value;
} else {
while (temp.length() < totalWidth) {
temp = paddingChar + temp;
}
return temp;
}
}
/**
* java trim()重写,取出字符串前后空格 add 2009-5-5 by sumfing
*/
public static String reTrimByString(String value) {
String reValue;
if (value == null || value.equals("")) {
reValue = "";
} else {
reValue = value.trim();
}
return reValue;
}
public static String reTrimByObject(Object obj) {
String reValue;
if (obj == null || obj.equals("")) {
reValue = "";
} else {
reValue = String.valueOf(obj).trim();
}
return reValue;
}
/**
* 类似String.indexOf() 返回字符串在数组中的位置
*
* @param strArr
* @param str
* @return
*/
public static int indexOfStringArray(String[] strArr, String str) {
int index = -1;
if (strArr != null && str != null) {
for (int i = 0; i < strArr.length; i++) {
if (str.equals(strArr[i])) {
index = i;
break;
}
}
}
return index;
}
/**
* 替换特定的字符串,替换位置为第一次遇到的
*
* @param whole 完整的字符串
* @param strold 要被替换的字符串
* @param strnew 替换的字符串
* @return
*/
public static String replaceFirst(String whole, String strold, String strnew) {
if (whole.indexOf(strold) > -1 && strnew != null) {
String whole_one = whole.substring(0, whole.indexOf(strold));
String whole_two = whole.substring(whole.indexOf(strold) + strold.length());
whole = whole_one + strnew + whole_two;
}
return whole;
}
/**
* 将字符串加上单引号
*
* @param strs
* @param splitChar
* @return '','',''
*/
public static String addDyh(String strs, String splitChar) {
if (!isEmpty(strs)) {
if (isEmpty(splitChar))
splitChar = ",";
String[] ss = strs.split(splitChar);
String reStrs = "";
for (int i = 0; i < ss.length; i++) {
if (!isEmpty(ss[i])) {
reStrs += splitChar + "'" + ss[i] + "'";
}
}
if (!isEmpty(reStrs))
reStrs = reStrs.substring(1);
return reStrs;
}
return strs;
}
/**
* 将String数组转换为Long类型数组
*
* @param strs
* @return
*/
public static Long[] convertionToLong(String[] strs) {
Long[] longs = null;
if (!isEmpty(strs)) {
longs = new Long[strs.length];
for (int i = 0; i < strs.length; i++) {
String str = strs[i];
long thelong = Long.valueOf(str);
longs[i] = thelong;
}
}
return longs;
}
/**
* 将String转换为Long类型数组
*
* @param strs
* @param splitChar 分割字符
* @return
*/
public static Long[] convertionToLongArr(String strs, String splitChar) {
if (isEmpty(splitChar))
splitChar = ",";
Long[] result = null;
if (!StringUtil.isEmpty(strs)) {
String[] ids = strs.split(splitChar);
result = new Long[ids.length];
for (int i = 0; i < ids.length; i++) {
result[i] = new Long(ids[i]);
}
}
return result;
}
/**
* 将String转换为List类型数组
*
* @param strs
* @param splitChar 分割字符
* @return
*/
public static List<String> convertionToList(String strs, String splitChar) {
if (isEmpty(splitChar)) {
splitChar = ",";
}
List<String> result = null;
if (!StringUtil.isEmpty(strs)) {
String[] ids = strs.split(splitChar);
result = new ArrayList<String>();
for (int i = 0; i < ids.length; i++) {
result.add(ids[i]);
}
}
return result;
}
/**
* 将String转换为List类型数组,不去空
*
* @param strs
* @param splitChar 分割字符
* @return
*/
public static List<String> convertionToListWithEmpty(String strs, String splitChar) {
if (isEmpty(splitChar)) {
splitChar = ",";
}
List<String> result = null;
if (!StringUtil.isEmpty(strs)) {
String[] ids = strs.split(splitChar, -1);
result = new ArrayList<String>();
for (int i = 0; i < ids.length; i++) {
result.add(ids[i]);
}
}
return result;
}
/**
* Long[] 转成 String
*
* @param l
* @param splitChar
* @return
*/
public static String convertionLongToString(Long[] l, String splitChar) {
String result = null;
if (l != null) {
result = Arrays.toString(l);
result = result.substring(1, result.length() - 1);
if (!StringUtil.isEmpty(splitChar)) {
result = result.replaceAll(",", splitChar);
}
}
return result;
}
/**
* Short[] 转成 String
*
* @param l
* @param splitChar
* @return
*/
public static String convertionShortToString(Short[] l, String splitChar) {
String result = null;
if (l != null) {
result = Arrays.toString(l);
result = result.substring(1, result.length() - 1);
if (!StringUtil.isEmpty(splitChar)) {
result = result.replaceAll(",", splitChar);
}
}
return result;
}
/**
* List<Long> 转成 String
*
* @param l
* @param splitChar
* @return
*/
public static String convertionLongToString(List<Long> l, String splitChar) {
StringBuffer result = new StringBuffer();
if (l != null && l.size() > 0) {
for (int i = 0; i < l.size(); i++) {
Long ll = l.get(i);
if (ll != null) {
result.append(ll);
if (i != l.size() - 1)
result.append(splitChar);
}
}
}
return result.toString();
}
/**
* List<Short> 转成 String
*
* @param l
* @param splitChar
* @return
*/
public static String convertionShortToString(List<Short> l, String splitChar) {
StringBuffer result = new StringBuffer();
if (l != null && l.size() > 0) {
for (int i = 0; i < l.size(); i++) {
Short ll = l.get(i);
if (ll != null) {
result.append(ll);
if (i != l.size() - 1)
result.append(splitChar);
}
}
}
return result.toString();
}
/**
* List<String> 转成 String
*
* @param l
* @param splitChar
* @param addYh 是否给每个字符串加上引号
* @return
*/
public static String convertionArrToString(List<String> l, String splitChar, boolean addYh) {
StringBuffer result = new StringBuffer();
if (l != null && l.size() > 0) {
for (int i = 0; i < l.size(); i++) {
String ll = l.get(i);
if (ll != null) {
if (addYh) {
result.append("'" + ll + "'");
} else {
result.append(ll);
}
if (i != l.size() - 1)
result.append(splitChar);
}
}
}
return result.toString();
}
/**
* 将字符串str里的某些字符sregex转义成指定的字符sreplace
*
* @param str
* @param sregex
* @param sreplace
* @return String
*/
public static String getStrTransMean(String str, String sregex, String sreplace) {
if (!StringUtil.isEmpty(str)) {
str = str.replaceAll(sregex, sreplace);
}
return str;
}
/**
* 通过指定长度分拆字符串,len个一组,装入list
*
* @param str
* @param len
* @return List<String>
*/
public static List<String> splitStringByLength(String str, int len) {
List<String> list = new ArrayList<String>();
if (str != null && str.length() > 0) {
String[] strArr = str.split(",");
int mod = strArr.length % len;
int divide = strArr.length / len;
int time = mod == 0 ? divide : divide + 1;
for (int i = 0; i < time; i++) {
int end = (i + 1) * len;
if (strArr.length - i * len < len) {
end = strArr.length;
}
String temp = "";
for (int j = i * len; j < end; j++) {
temp += strArr[j] + ",";
}
list.add(temp.substring(0, temp.length() - 1));
}
return list;
} else {
return null;
}
}
/**
* Object转换成Long型
*
* @param obj
* @return
*/
public static Long convertToLong(Object obj) {
if (obj != null) {
return Long.valueOf(String.valueOf(obj));
}
return null;
}
/**
* Object转换成Short型
*
* @param obj
* @return
*/
public static Short convertToShort(Object obj) {
if (obj != null) {
return Short.valueOf(String.valueOf(obj));
}
return null;
}
public static String rightTrim(String str) {
if (str == null) {
return "";
}
int length = str.length();
for (int i = length - 1; i >= 0; i++) {
if (str.charAt(i) != 0x20) {
break;
}
length--;
}
return str.substring(0, length);
}
/**
* 判断是否为数字
*
* @param str
* @return
*/
public static boolean isNumber(String str) {
if (!isEmpty(str)) {
Pattern pattern = Pattern.compile("[0-9]*");
return pattern.matcher(str).matches();
}
return false;
}
/**
* 根据字节下标取字符下标(当截取的字节为半字符则不取)
*
* @param str
* @param byteInt
* @return
*/
public static int getCharInt(String str, int byteInt) {
int l = 0;
if (!isEmpty(str)) {
char[] cs = str.toCharArray();
int g = 0;
// for(int b = 0;b<cs.length;b++){
// char c = cs[b];
for (char c : cs) {
byte[] ss = String.valueOf(c + "").getBytes();
g += ss.length;
if (g > byteInt) {
g -= ss.length;
l -= 1;
break;
}
l += 1;
}
}
return l;
}
/**
* 计算replacedStr在sourceStr中出现的次数
*
* @param sourceStr
* @param replacedStr
* @param str
* @return
* @Title: countStrTimesByStr
* @date 2013-3-19 下午03:36:19
*/
public static int countStrTimesByStr(String sourceStr, String replacedStr) {
return (sourceStr.length() - sourceStr.replace(replacedStr, "").length()) / replacedStr.length();
}
/**
* 将null字符串 转成""
*
* @param str
* @return
*/
public static String convertNullStr(String str) {
if (isEmpty(str)) {
return "";
}
return str;
}
/**
* @param str 字符串
* @return boolean 返回类型
* @throws
* @Title: isChineseChar
* @Description: 字符串是否包含中文字符
* @author LFG
*/
public static boolean isContainChineseChar(String str) {
boolean temp = false;
Pattern p = Pattern.compile("[\u4e00-\u9fa5]");
Matcher m = p.matcher(str);
if (m.find()) {
temp = true;
}
return temp;
}
/**
* @param str
* @return String 返回类型
* @throws
* @Title: formatChineseStr
* @Description: 格式化中文名(两个汉字,则加空格)
* @author LFG
*/
public static String formatChineseStr(String str) {
if (StringUtil.isEmpty(str)) {
return "";
}
str = str.replaceAll(" ", "");
String resultStr = str;
if (isContainChineseChar(str)) {// 包含中文
if (str.length() == 2) {
resultStr = str.substring(0, 1) + " " + str.substring(1, 2);
}
}
return resultStr;
}
/**
* @param str
* @return Boolean 返回类型
* @throws
* @Title: formatChineseStr
* @Description: 格式化中文名(两个汉字,则加空格)
* @author LFG
*/
public static Boolean isTwoChineseStr(String str) {
if (StringUtil.isEmpty(str)) {
return false;
}
if (isContainChineseChar(str)) {// 包含中文
if (str.length() == 2) {
return true;
}
}
return false;
}
/**
* @param str 民族
* @return String 返回类型
* @throws
* @Title: formatOrigin
* @Description: 格式化民族名称(如果以族结尾则去掉族,否则原样返回)
* @author LFG
*/
public static String formatOrigin(String str) {
if (StringUtil.isEmpty(str)) {
return "";
}
String resultStr = str;
if ("族".equals(str.substring(str.length() - 1, str.length()))) {
resultStr = str.substring(0, str.length() - 1);
}
return resultStr;
}
public static int countSingleByteEleNum(String str) {
int count = 0;
if (str == null) {
return 0;
}
for (int i = 0; i < str.length(); i++) {
char charCode = str.charAt(i);
if (charCode >= 0 && charCode <= 128) {
count += 1;
}
}
return count;
}
public static String formatWrap(String manualResume) {
if (StringUtil.isNotEmpty(manualResume)) {
return manualResume.replaceAll("\r\n", "\r").replaceAll("\n", "\r").replaceAll("\r", "\r\n");
} else {
return "";
}
}
public static String ltrim(String str) {
if (isEmpty(str)) {
return "";
}
int startIndex = str.indexOf(str.trim().charAt(0) + "");
return str.substring(startIndex);
}
public static String trim(String str) {
if (isEmpty(str)) {
return "";
}
return str.trim();
}
public static String formatWrapByExcel(String str) {
if (StringUtils.isNotEmpty(str)) {
str = str.replaceAll("\r\n", "\r").replaceAll("\n", "\r").replaceAll("<br>", "\r").replaceAll("\r", "\r\n");
}
return str;
}
public static String formatBackslashByHtml(String str) {
if (isEmpty(str)) {
return "";
}
return str.replaceAll("\\\\", "\");
}
public static Boolean isBelongAWordAndNotEnd(String str, Integer index) {
if (str.length() <= index + 1) {
return false;
}
char charCode = str.charAt(index);
if (charCode > 128 || charCode == ' ') {
return false;
}
char charCodeSec = str.charAt(index + 1);
if (charCodeSec > 128 || charCodeSec == ' ') {
return false;
}
return true;
}
public static String cullLastWord(String str) {
for (int i = str.length() - 1; i > 0; i--) {
char charCode = str.charAt(i);
if (charCode > 128 || charCode == ' ') {
return str.substring(0, i + 1);
}
}
return str;
}
public static String replaceDot(String object) {
if (object != null) {
return object.replaceAll(",", ",");
}
return object;
}
public static String fomartEmpty(String str) {
if (isEmpty(str)) {
return "";
}
return str;
}
/**
* @param str
* @return Integer 返回类型
* @throws
* @Title: countNumAndEng
* @Description: 统计数字+英文字母个数
* @author LFG
*/
private static Integer countNumAndEng(String str) {
if (null == str || str.length() == 0) {
return 0;
}
String E2 = "[a-zA-Z]";// 英文
String E3 = "[0-9]";// 数字
int englishCount = 0;
int numberCount = 0;
String temp;
for (int i = 0; i < str.length(); i++) {
temp = String.valueOf(str.charAt(i));
if (temp.matches(E2)) {
englishCount++;
}
if (temp.matches(E3)) {
numberCount++;
}
}
return (str.length() - englishCount - numberCount) * 2 + englishCount + numberCount;
}
/**
* @param str
* @return Map<String,Object> 返回类型
* @throws
* @Title: countStrLen
* @Description: 计算中文、数字、英文、特殊字符数量
* @author LFG
*/
public static Map<String, Object> diffTypeCount(String str) {
if (null == str || str.length() == 0) {
return null;
}
Map<String, Object> resultMap = new HashMap<String, Object>();
String E1 = "[\u4e00-\u9fa5]";// 中文
String E2 = "[a-zA-Z]";// 英文
String E3 = "[0-9]";// 数字
String E4 = ".";// .
String E5 = "-";// -
int chineseCount = 0;
int englishCount = 0;
int numberCount = 0;
int dotCount = 0;
int minCount = 0;
String temp;
for (int i = 0; i < str.length(); i++) {
temp = String.valueOf(str.charAt(i));
if (temp.matches(E1)) {
chineseCount++;
}
if (temp.matches(E2)) {
englishCount++;
}
if (temp.matches(E3)) {
numberCount++;
}
if (temp.contains(E4)) {
dotCount++;
}
if (temp.contains(E5)) {
minCount++;
}
}
resultMap.put("chnCount", chineseCount);
resultMap.put("engCount", englishCount);
resultMap.put("numCount", numberCount);
resultMap.put("dotCount", dotCount);
resultMap.put("minCount", minCount);
resultMap.put("specCount", (str.length() - (chineseCount + englishCount + numberCount + dotCount + minCount)));
return resultMap;
}
public static Integer countStrLength(String str) {
Integer count = 0;
if (null == str || "".equals(str)) {
return 0;
}
str = str.replaceAll("<span style='color:red;'>", "").replaceAll("</span>", "").replaceAll("\r\n", "");
Map<String, Object> map = diffTypeCount(str);
Integer engCount = (Integer) map.get("engCount");
Integer numCount = (Integer) map.get("numCount");
Integer dotCount = (Integer) map.get("dotCount");
Integer minCount = (Integer) map.get("minCount");
int twoByteCount = str.length() - (engCount + numCount + dotCount + minCount);// 2个字节
int oneByteCount = engCount + numCount + dotCount + minCount;
count = twoByteCount + oneByteCount / 2;
return count;
}
/**
* @param str
* @param count
* @return String 返回类型
* @throws
* @Title: countStrLen
* @Description: 根据总长度计算返回字符串(注:中文和特殊字符算2个字符,其余算一个字符)
* @author LFG
*/
public static String countStrLen(String str, Integer count) {
if (null == str || str.length() == 0) {
return "";
}
if (countNumAndEng(str) <= count) {
return str;
}
// String E1 = "[\u4e00-\u9fa5]";// 中文
String E2 = "[a-zA-Z]";// 英文
String E3 = "[0-9]";// 数字
Integer index = 0;
Integer i = 0;
StringBuffer resultStr = new StringBuffer("");
while (index < count) {
String temp = String.valueOf(str.charAt(i));
i++;
if (temp.matches(E2) || temp.matches(E3)) {
index++;
} else {
index = index + 2;
}
resultStr.append(temp);
}
if (index > count) {
resultStr.append("...");
}
return resultStr.toString() + "";
}
public static void main(String[] args) {
String str = "(...2016.05--2016.05 在大专学校机修学习 2014.05--2016.06 莆田市委员(其间:2015.02--2015.08参加培训班名称学习;2016.05--2016.05参加中专学校名称挖掘机专业在职学习;2016.05--2016.05参加学士学位授予学校攻读学士学位,获得农学学士学位;2016.05--2016.05参加博士学位授予学校攻读博士学位,获得经济学博士学位;2016.05--2016.05参加中专学校名称挖掘机专业在职学习) 2016.05--2016.05 厦门市审纪员 (其间:2016.05--2016.05参加中专学校名称挖掘机专业在职学习) 2016.05--2016.05 厦门市审纪员,书记 (2016.05--2016.05参加学士学位授予学校攻读学士学位,获得农学学士学位;2016.05--2016.05参加博士学位授予学校攻读博士学位,获得经济学博士学位) 2016.05--2016.07 厦门市审纪员,书记,厦门市审纪员、省领导干部 2016.07-- 厦门市审纪员,书记,厦门市审纪员、省领导干部,省投资开发集团公司书记...)";
System.out.println(countStrLength(str));
System.out.println(390 / 60 + 1);
}
/**
* 截取字符串中字母部分<br>
* 只适用于 AA123 这样的格式,返回123
*
* @param str
* @return
*/
public static String cutToNum(String str) {
String retuStr = "";
for (int i = str.length(); i > 0; i--) {
if (isNumber(str.charAt(i - 1) + "")) {
retuStr = str.charAt(i - 1) + retuStr;
} else {
break;
}
}
return retuStr;
}
/**
* 截取字符串中字母部分<br>
* 只适用于 AA123 这样的格式,返回AA
*
* @param str
* @return
*/
public static String cutToStr(String str) {
String retuStr = "";
for (int i = 0; i < str.length(); i++) {
if (isNumber(str.charAt(i) + "")) {
break;
} else {
retuStr += str.charAt(i);
}
}
return retuStr;
}
public static String decimalToAlphabetBinary(Integer num) {
if (num == null || num < 0) {
return "";
}
char numChar = 'A';
Integer numA = (int) numChar;
String result = "";
while (num.compareTo(26) >= 0) {
Integer val = num % 26;
result = String.valueOf((char) (numA + val)) + result;
num = num / 26 - 1;
}
result = String.valueOf((char) (numA + num)) + result;
return result;
}
public static String getInParameter(List<String> list, String parameter) {
if (!list.isEmpty()) {
List<String> setList = new ArrayList<String>(0);
Set<String> set = new HashSet<String>();
StringBuffer stringBuffer = new StringBuffer();
for (int i = 1; i <= list.size(); i++) {
set.add("'" + list.get(i - 1) + "'");
if (i % 500 == 0) {//500为阈值
setList.add(StringUtils.join(set.iterator(), ","));
set.clear();
}
}
if (!set.isEmpty()) {
setList.add(StringUtils.join(set.iterator(), ","));
}
stringBuffer.append(parameter + " in ( " + setList.get(0));
for (int j = 1; j < setList.size(); j++) {
stringBuffer.append(") or " + parameter + " in (");
stringBuffer.append(setList.get(j));
}
stringBuffer.append(" ) ");
return "and ( " + stringBuffer.toString() + " ) ";
} else {
return "''";
}
}
public static String[] split(String string, String paramString) {
List<String> info = new ArrayList<String>();
Integer index = -1;
while ((index = string.indexOf(paramString)) >= 0) {
if (index == 0) {
info.add("");
} else {
info.add(string.substring(0, index));
}
string = string.substring(index + 1);
}
info.add(string);
return info.toArray(new String[]{});
}
}
package com.loit.seata.order.example.web.utils;
\ No newline at end of file
feign:
sentinel:
enabled: true
logging:
level:
io:
seata: debug
management:
endpoints:
web:
exposure:
include: '*'
server:
port: 9091
spring:
application:
name: order-service
cloud:
alibaba:
seata:
# seata 服务分组,要与服务端nacos-config.txt中service.vgroup_mapping的后缀对应
tx-service-group: order-service-seata-service-group
nacos:
discovery:
# Nacos 注册中心地址
server-addr: 39.100.254.140:8103
namespace: 3ac84119-5558-4bf8-b309-034dd0e458e0
sentinel:
datasource:
ds:
nacos:
dataId: ${spring.application.name}-sentinel
groupId: DEFAULT_GROUP
rule-type: flow
server-addr: 39.100.254.140:8103
namespace: 3ac84119-5558-4bf8-b309-034dd0e458e0
transport:
dashboard: localhost:8090
port: 8720
datasource:
# 数据源配置
druid:
driverClassName: com.mysql.jdbc.Driver
password: abcd1234A!
url: jdbc:mysql://39.98.202.173:3306/seata_order?allowMultiQueries=true&useUnicode=true&characterEncoding=utf-8&useSSL=false
username: root
user:
age: 24
name: example-yaml
spring.profiles.active=dev
spring.application.name=order-service-example
# Nacos ĵַ
spring.cloud.nacos.config.server-addr=39.100.254.140:8103
spring.cloud.nacos.config.group=DEFAULT_GROUP
# spring.cloud.nacos.config.file-extension=properties
spring.cloud.nacos.config.file-extension=yaml
spring.cloud.nacos.config.namespace=3ac84119-5558-4bf8-b309-034dd0e458e0
transport {
# tcp udt unix-domain-socket
type = "TCP"
#NIO NATIVE
server = "NIO"
#enable heartbeat
heartbeat = true
#thread factory for netty
thread-factory {
boss-thread-prefix = "NettyBoss"
worker-thread-prefix = "NettyServerNIOWorker"
server-executor-thread-prefix = "NettyServerBizHandler"
share-boss-worker = false
client-selector-thread-prefix = "NettyClientSelector"
client-selector-thread-size = 1
client-worker-thread-prefix = "NettyClientWorkerThread"
# netty boss thread size,will not be used for UDT
boss-thread-size = 1
#auto default pin or 8
worker-thread-size = 8
}
shutdown {
# when destroy server, wait seconds
wait = 3
}
serialization = "seata"
compressor = "none"
}
service {
#transaction service group mapping
vgroup_mapping.order-service-seata-service-group = "default"
#only support when registry.type=file, please don't set multiple addresses
default.grouplist = "127.0.0.1:8091"
#degrade, current not support
enableDegrade = false
#disable seata
disableGlobalTransaction = false
}
client {
rm {
async.commit.buffer.limit = 10000
lock {
retry.internal = 10
retry.times = 30
retry.policy.branch-rollback-on-conflict = true
}
report.retry.count = 5
table.meta.check.enable = false
report.success.enable = true
}
tm {
commit.retry.count = 5
rollback.retry.count = 5
}
undo {
data.validation = true
log.serialization = "jackson"
log.table = "undo_log"
}
log {
exceptionRate = 100
}
support {
# auto proxy the DataSource bean
spring.datasource.autoproxy = false
}
}
## transaction log store
store {
## store mode: file、db
mode = "db"
## file store property
file {
## store location dir
dir = "sessionStore"
# branch session size , if exceeded first try compress lockkey, still exceeded throws exceptions
max-branch-session-size = 16384
# globe session size , if exceeded throws exceptions
max-global-session-size = 512
# file buffer size , if exceeded allocate new buffer
file-write-buffer-cache-size = 16384
# when recover batch read size
session.reload.read_size = 100
# async, sync
flush-disk-mode = async
}
## database store property
db {
## the implement of javax.sql.DataSource, such as DruidDataSource(druid)/BasicDataSource(dbcp) etc.
datasource = "dbcp"
## mysql/oracle/h2/oceanbase etc.
db-type = "mysql"
driver-class-name = "com.mysql.jdbc.Driver"
url = "jdbc:mysql://39.98.202.173:3306/seata_server"
user = "root"
password = "abcd1234A!"
min-conn = 1
max-conn = 10
global.table = "global_table"
branch.table = "branch_table"
lock-table = "lock_table"
query-limit = 100
}
}
server {
recovery {
#schedule committing retry period in milliseconds
committing-retry-period = 1000
#schedule asyn committing retry period in milliseconds
asyn-committing-retry-period = 1000
#schedule rollbacking retry period in milliseconds
rollbacking-retry-period = 1000
#schedule timeout retry period in milliseconds
timeout-retry-period = 1000
}
undo {
log.save.days = 7
#schedule delete expired undo_log in milliseconds
log.delete.period = 86400000
}
#unit ms,s,m,h,d represents milliseconds, seconds, minutes, hours, days, default permanent
max.commit.retry.timeout = "-1"
max.rollback.retry.timeout = "-1"
}
## metrics settings
metrics {
enabled = false
registry-type = "compact"
# multi exporters use comma divided
exporter-list = "prometheus"
exporter-prometheus-port = 9898
}
\ No newline at end of file
registry {
# file 、nacos 、eureka、redis、zk、consul、etcd3、sofa
type = "nacos"
nacos {
serverAddr = "39.100.254.140:8103"
namespace = "public"
cluster = "default"
}
eureka {
serviceUrl = "http://localhost:8761/eureka"
application = "default"
weight = "1"
}
redis {
serverAddr = "localhost:6379"
db = "0"
}
zk {
cluster = "default"
serverAddr = "127.0.0.1:2181"
session.timeout = 6000
connect.timeout = 2000
}
consul {
cluster = "default"
serverAddr = "127.0.0.1:8500"
}
etcd3 {
cluster = "default"
serverAddr = "http://localhost:2379"
}
sofa {
serverAddr = "127.0.0.1:9603"
application = "default"
region = "DEFAULT_ZONE"
datacenter = "DefaultDataCenter"
cluster = "default"
group = "SEATA_GROUP"
addressWaitTime = "3000"
}
file {
name = "file.conf"
}
}
config {
# file、nacos 、apollo、zk、consul、etcd3
type = "file"
nacos {
serverAddr = "39.100.254.140:8103"
namespace = "public"
}
consul {
serverAddr = "127.0.0.1:8500"
}
apollo {
app.id = "seata-server"
apollo.meta = "http://192.168.1.204:8801"
}
zk {
serverAddr = "127.0.0.1:2181"
session.timeout = 6000
connect.timeout = 2000
}
etcd3 {
serverAddr = "http://localhost:2379"
}
file {
name = "file.conf"
}
}
#!/bin/sh
# ----------------------------------------------------------------------------
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
# ----------------------------------------------------------------------------
# ----------------------------------------------------------------------------
# Maven Start Up Batch script
#
# Required ENV vars:
# ------------------
# JAVA_HOME - location of a JDK home dir
#
# Optional ENV vars
# -----------------
# M2_HOME - location of maven2's installed home dir
# MAVEN_OPTS - parameters passed to the Java VM when running Maven
# e.g. to debug Maven itself, use
# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
# MAVEN_SKIP_RC - flag to disable loading of mavenrc files
# ----------------------------------------------------------------------------
if [ -z "$MAVEN_SKIP_RC" ] ; then
if [ -f /etc/mavenrc ] ; then
. /etc/mavenrc
fi
if [ -f "$HOME/.mavenrc" ] ; then
. "$HOME/.mavenrc"
fi
fi
# OS specific support. $var _must_ be set to either true or false.
cygwin=false;
darwin=false;
mingw=false
case "`uname`" in
CYGWIN*) cygwin=true ;;
MINGW*) mingw=true;;
Darwin*) darwin=true
# Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
# See https://developer.apple.com/library/mac/qa/qa1170/_index.html
if [ -z "$JAVA_HOME" ]; then
if [ -x "/usr/libexec/java_home" ]; then
export JAVA_HOME="`/usr/libexec/java_home`"
else
export JAVA_HOME="/Library/Java/Home"
fi
fi
;;
esac
if [ -z "$JAVA_HOME" ] ; then
if [ -r /etc/gentoo-release ] ; then
JAVA_HOME=`java-config --jre-home`
fi
fi
if [ -z "$M2_HOME" ] ; then
## resolve links - $0 may be a link to maven's home
PRG="$0"
# need this for relative symlinks
while [ -h "$PRG" ] ; do
ls=`ls -ld "$PRG"`
link=`expr "$ls" : '.*-> \(.*\)$'`
if expr "$link" : '/.*' > /dev/null; then
PRG="$link"
else
PRG="`dirname "$PRG"`/$link"
fi
done
saveddir=`pwd`
M2_HOME=`dirname "$PRG"`/..
# make it fully qualified
M2_HOME=`cd "$M2_HOME" && pwd`
cd "$saveddir"
# echo Using m2 at $M2_HOME
fi
# For Cygwin, ensure paths are in UNIX format before anything is touched
if $cygwin ; then
[ -n "$M2_HOME" ] &&
M2_HOME=`cygpath --unix "$M2_HOME"`
[ -n "$JAVA_HOME" ] &&
JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
[ -n "$CLASSPATH" ] &&
CLASSPATH=`cygpath --path --unix "$CLASSPATH"`
fi
# For Mingw, ensure paths are in UNIX format before anything is touched
if $mingw ; then
[ -n "$M2_HOME" ] &&
M2_HOME="`(cd "$M2_HOME"; pwd)`"
[ -n "$JAVA_HOME" ] &&
JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`"
fi
if [ -z "$JAVA_HOME" ]; then
javaExecutable="`which javac`"
if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then
# readlink(1) is not available as standard on Solaris 10.
readLink=`which readlink`
if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then
if $darwin ; then
javaHome="`dirname \"$javaExecutable\"`"
javaExecutable="`cd \"$javaHome\" && pwd -P`/javac"
else
javaExecutable="`readlink -f \"$javaExecutable\"`"
fi
javaHome="`dirname \"$javaExecutable\"`"
javaHome=`expr "$javaHome" : '\(.*\)/bin'`
JAVA_HOME="$javaHome"
export JAVA_HOME
fi
fi
fi
if [ -z "$JAVACMD" ] ; then
if [ -n "$JAVA_HOME" ] ; then
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
# IBM's JDK on AIX uses strange locations for the executables
JAVACMD="$JAVA_HOME/jre/sh/java"
else
JAVACMD="$JAVA_HOME/bin/java"
fi
else
JAVACMD="`which java`"
fi
fi
if [ ! -x "$JAVACMD" ] ; then
echo "Error: JAVA_HOME is not defined correctly." >&2
echo " We cannot execute $JAVACMD" >&2
exit 1
fi
if [ -z "$JAVA_HOME" ] ; then
echo "Warning: JAVA_HOME environment variable is not set."
fi
CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher
# traverses directory structure from process work directory to filesystem root
# first directory with .mvn subdirectory is considered project base directory
find_maven_basedir() {
if [ -z "$1" ]
then
echo "Path not specified to find_maven_basedir"
return 1
fi
basedir="$1"
wdir="$1"
while [ "$wdir" != '/' ] ; do
if [ -d "$wdir"/.mvn ] ; then
basedir=$wdir
break
fi
# workaround for JBEAP-8937 (on Solaris 10/Sparc)
if [ -d "${wdir}" ]; then
wdir=`cd "$wdir/.."; pwd`
fi
# end of workaround
done
echo "${basedir}"
}
# concatenates all lines of a file
concat_lines() {
if [ -f "$1" ]; then
echo "$(tr -s '\n' ' ' < "$1")"
fi
}
BASE_DIR=`find_maven_basedir "$(pwd)"`
if [ -z "$BASE_DIR" ]; then
exit 1;
fi
##########################################################################################
# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
# This allows using the maven wrapper in projects that prohibit checking in binary data.
##########################################################################################
if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found .mvn/wrapper/maven-wrapper.jar"
fi
else
if [ "$MVNW_VERBOSE" = true ]; then
echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..."
fi
if [ -n "$MVNW_REPOURL" ]; then
jarUrl="$MVNW_REPOURL/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
else
jarUrl="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
fi
while IFS="=" read key value; do
case "$key" in (wrapperUrl) jarUrl="$value"; break ;;
esac
done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties"
if [ "$MVNW_VERBOSE" = true ]; then
echo "Downloading from: $jarUrl"
fi
wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar"
if $cygwin; then
wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"`
fi
if command -v wget > /dev/null; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found wget ... using wget"
fi
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
wget "$jarUrl" -O "$wrapperJarPath"
else
wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath"
fi
elif command -v curl > /dev/null; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found curl ... using curl"
fi
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
curl -o "$wrapperJarPath" "$jarUrl" -f
else
curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f
fi
else
if [ "$MVNW_VERBOSE" = true ]; then
echo "Falling back to using Java to download"
fi
javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java"
# For Cygwin, switch paths to Windows format before running javac
if $cygwin; then
javaClass=`cygpath --path --windows "$javaClass"`
fi
if [ -e "$javaClass" ]; then
if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
if [ "$MVNW_VERBOSE" = true ]; then
echo " - Compiling MavenWrapperDownloader.java ..."
fi
# Compiling the Java class
("$JAVA_HOME/bin/javac" "$javaClass")
fi
if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
# Running the downloader
if [ "$MVNW_VERBOSE" = true ]; then
echo " - Running MavenWrapperDownloader.java ..."
fi
("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR")
fi
fi
fi
fi
##########################################################################################
# End of extension
##########################################################################################
export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}
if [ "$MVNW_VERBOSE" = true ]; then
echo $MAVEN_PROJECTBASEDIR
fi
MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS"
# For Cygwin, switch paths to Windows format before running java
if $cygwin; then
[ -n "$M2_HOME" ] &&
M2_HOME=`cygpath --path --windows "$M2_HOME"`
[ -n "$JAVA_HOME" ] &&
JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"`
[ -n "$CLASSPATH" ] &&
CLASSPATH=`cygpath --path --windows "$CLASSPATH"`
[ -n "$MAVEN_PROJECTBASEDIR" ] &&
MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"`
fi
# Provide a "standardized" way to retrieve the CLI args that will
# work with both Windows and non-Windows executions.
MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@"
export MAVEN_CMD_LINE_ARGS
WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
exec "$JAVACMD" \
$MAVEN_OPTS \
-classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \
"-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \
${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@"
@REM ----------------------------------------------------------------------------
@REM Licensed to the Apache Software Foundation (ASF) under one
@REM or more contributor license agreements. See the NOTICE file
@REM distributed with this work for additional information
@REM regarding copyright ownership. The ASF licenses this file
@REM to you under the Apache License, Version 2.0 (the
@REM "License"); you may not use this file except in compliance
@REM with the License. You may obtain a copy of the License at
@REM
@REM https://www.apache.org/licenses/LICENSE-2.0
@REM
@REM Unless required by applicable law or agreed to in writing,
@REM software distributed under the License is distributed on an
@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
@REM KIND, either express or implied. See the License for the
@REM specific language governing permissions and limitations
@REM under the License.
@REM ----------------------------------------------------------------------------
@REM ----------------------------------------------------------------------------
@REM Maven Start Up Batch script
@REM
@REM Required ENV vars:
@REM JAVA_HOME - location of a JDK home dir
@REM
@REM Optional ENV vars
@REM M2_HOME - location of maven2's installed home dir
@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands
@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending
@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven
@REM e.g. to debug Maven itself, use
@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files
@REM ----------------------------------------------------------------------------
@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on'
@echo off
@REM set title of command window
title %0
@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on'
@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO%
@REM set %HOME% to equivalent of $HOME
if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%")
@REM Execute a user defined script before this one
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre
@REM check for pre script, once with legacy .bat ending and once with .cmd ending
if exist "%HOME%\mavenrc_pre.bat" call "%HOME%\mavenrc_pre.bat"
if exist "%HOME%\mavenrc_pre.cmd" call "%HOME%\mavenrc_pre.cmd"
:skipRcPre
@setlocal
set ERROR_CODE=0
@REM To isolate internal variables from possible post scripts, we use another setlocal
@setlocal
@REM ==== START VALIDATION ====
if not "%JAVA_HOME%" == "" goto OkJHome
echo.
echo Error: JAVA_HOME not found in your environment. >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
:OkJHome
if exist "%JAVA_HOME%\bin\java.exe" goto init
echo.
echo Error: JAVA_HOME is set to an invalid directory. >&2
echo JAVA_HOME = "%JAVA_HOME%" >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
@REM ==== END VALIDATION ====
:init
@REM Find the project base dir, i.e. the directory that contains the folder ".mvn".
@REM Fallback to current working directory if not found.
set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR%
IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir
set EXEC_DIR=%CD%
set WDIR=%EXEC_DIR%
:findBaseDir
IF EXIST "%WDIR%"\.mvn goto baseDirFound
cd ..
IF "%WDIR%"=="%CD%" goto baseDirNotFound
set WDIR=%CD%
goto findBaseDir
:baseDirFound
set MAVEN_PROJECTBASEDIR=%WDIR%
cd "%EXEC_DIR%"
goto endDetectBaseDir
:baseDirNotFound
set MAVEN_PROJECTBASEDIR=%EXEC_DIR%
cd "%EXEC_DIR%"
:endDetectBaseDir
IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig
@setlocal EnableExtensions EnableDelayedExpansion
for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a
@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS%
:endReadAdditionalConfig
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar"
set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
FOR /F "tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B
)
@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
@REM This allows using the maven wrapper in projects that prohibit checking in binary data.
if exist %WRAPPER_JAR% (
if "%MVNW_VERBOSE%" == "true" (
echo Found %WRAPPER_JAR%
)
) else (
if not "%MVNW_REPOURL%" == "" (
SET DOWNLOAD_URL="%MVNW_REPOURL%/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
)
if "%MVNW_VERBOSE%" == "true" (
echo Couldn't find %WRAPPER_JAR%, downloading it ...
echo Downloading from: %DOWNLOAD_URL%
)
powershell -Command "&{"^
"$webclient = new-object System.Net.WebClient;"^
"if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^
"$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^
"}"^
"[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^
"}"
if "%MVNW_VERBOSE%" == "true" (
echo Finished downloading %WRAPPER_JAR%
)
)
@REM End of extension
@REM Provide a "standardized" way to retrieve the CLI args that will
@REM work with both Windows and non-Windows executions.
set MAVEN_CMD_LINE_ARGS=%*
%MAVEN_JAVA_EXE% %JVM_CONFIG_MAVEN_PROPS% %MAVEN_OPTS% %MAVEN_DEBUG_OPTS% -classpath %WRAPPER_JAR% "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %*
if ERRORLEVEL 1 goto error
goto end
:error
set ERROR_CODE=1
:end
@endlocal & set ERROR_CODE=%ERROR_CODE%
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPost
@REM check for post script, once with legacy .bat ending and once with .cmd ending
if exist "%HOME%\mavenrc_post.bat" call "%HOME%\mavenrc_post.bat"
if exist "%HOME%\mavenrc_post.cmd" call "%HOME%\mavenrc_post.cmd"
:skipRcPost
@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on'
if "%MAVEN_BATCH_PAUSE%" == "on" pause
if "%MAVEN_TERMINATE_CMD%" == "on" exit %ERROR_CODE%
exit /B %ERROR_CODE%
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<modules>
<module>loit-seata-order-example-dependencies</module>
<module>loit-seata-order-example-main</module>
</modules>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.6.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.loit.project</groupId>
<artifactId>loit-seata-order-example</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>pom</packaging>
<name>timeloit Seata Example</name>
<description>timeloit Seata Example</description>
<properties>
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<spring-boot.version>2.0.6.RELEASE</spring-boot.version>
<spring-cloud.version>Finchley.SR4</spring-cloud.version>
<spring-cloud-timeloit.version>0.0.1-SNAPSHOT</spring-cloud-timeloit.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>com.loit.project</groupId>
<artifactId>loit-seata-order-example-dependencies</artifactId>
<version>${project.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>com.timeloit.cloud</groupId>
<artifactId>spring-cloud-timeloit</artifactId>
<version>${spring-cloud-timeloit.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<distributionManagement>
<repository>
<id>nexus-releases</id>
<name>Nexus Release Repository</name>
<url>http://39.100.254.140:12010/repository/maven-releases/</url>
</repository>
<snapshotRepository>
<id>nexus-snapshots</id>
<name>Nexus Snapshot Repository</name>
<url>http://39.100.254.140:12010/repository/maven-snapshots/</url>
</snapshotRepository>
</distributionManagement>
<repositories>
<repository>
<id>nexus-loit-dev</id>
<name>Nexus Repository</name>
<url>http://39.100.254.140:12010/repository/maven-public/</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
<releases>
<enabled>true</enabled>
</releases>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>nexus-loit-dev</id>
<name>Nexus Plugin Repository</name>
<url>http://39.100.254.140:12010/repository/maven-public/</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
<releases>
<enabled>true</enabled>
</releases>
</pluginRepository>
</pluginRepositories>
</project>
\ No newline at end of file
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论