洞车常见问题解决指南

news2024/11/18 15:32:06

洞车常见问题解决指南

    • 1.研发脚本处理问题
      • 1.1 WMS出库单无法审核
      • 1.2 OMS入库单无法提交,提示更新中心库存失败
      • 1.3 当出现OMS下发成功WMS/TMS/DMS还没有任务的情况时处理方案
      • 1.4 调度波次生成或者添加任务系统异常
      • 1.5 东鹏出库单部分出库回传之后要求重传
      • 1.6 更新订单商品分类
      • 1.7 中心库存查询
      • 1.8 运输单全部任务已经签收,但是运输单仍是在途状态
    • 2.常用查询脚本
      • 2.1 查看主数据,导出主数据
      • 2.2 导出三级分类
      • 2.3 查询回传失败脚本
      • 2.4 查询订单商品行号重复脚本
      • 2.5 查询重复商品分类
    • 3 程序修复类
      • 3.1修复主数据
      • 3.1.1修复主数据的商品分类
      • 3.2 修改主数据的长宽高体积重量并下发
      • 3.3 订单签收状态重传

以下记录问题为常见的需要修改数据库才能解决的问题

1.研发脚本处理问题

1.1 WMS出库单无法审核

在这里插入图片描述
处理脚本

update wm_so_header set IS_SCHEDULE = 'N'  where SO_NO = 'SO单号'

1.2 OMS入库单无法提交,提示更新中心库存失败

导致这类问题的原因是中心库存的计划出库存大于在库库存
在这里插入图片描述
处理脚本,查看此账户是否存在计划出数量大于在库库存,查询脚本为:

select * from eo_virtual_inv_item where EOVI_OWNER_CODE = '客户编码' and  EOVI_QTY < P_OUT_QTY

EOVI_QTY :在库库存
P_OUT_QTY:计划出库存

1.3 当出现OMS下发成功WMS/TMS/DMS还没有任务的情况时处理方案

  • 第一步,需要将任务处理为新增状态
    在这里插入图片描述
    执行脚本:
update jrwl_oms2c.eo_c_work_order set EOWO_ISSUE_STATUS = null,EOWO_STATUS_CODE = '00' where EOWO_ORDER_NO = '物联单号';
  • 第二步,删除TMS的订单
select * from et_order where ETOR_EXTERNAL_ORDER_NO = '物联单号'; ## 选中之后手动删除
delete et_order where ETOR_EXTERNAL_ORDER_NO = '物联单号';
  • 第三步,操作下发
    在这里插入图片描述
    注意TMS和DMS的任务都需要删除对应的系统的订单,DMS订单,TMS订单

造成此问题的根本原因是:商品分类重复导致执行一下SQL报错
单行记录返回多行

SELECT
	(
	CASE
			( SELECT ( SELECT EBMG_STANDARD_HOURS FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =? ) IS NULL FROM DUAL ) 
			WHEN 1 THEN
			( SELECT EBMG_STANDARD_HOURS FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =( SELECT EBMG_PARENT_PM_CODE FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =? ) ) ELSE ( SELECT EBMG_STANDARD_HOURS FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =? ) 
		END 
		) AS EBMG_STANDARD_HOURS 
	FROM
		DUALSELECT (
		CASE
				( SELECT ( SELECT EBMG_STANDARD_HOURS FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =? ) IS NULL FROM DUAL ) 
				WHEN 1 THEN
				( SELECT EBMG_STANDARD_HOURS FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =( SELECT EBMG_PARENT_PM_CODE FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =? ) ) ELSE ( SELECT EBMG_STANDARD_HOURS FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =? ) 
			END 
			) AS EBMG_STANDARD_HOURS 
		FROM
			DUALSELECT (
			CASE
					( SELECT ( SELECT EBMG_STANDARD_HOURS FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =? ) IS NULL FROM DUAL ) 
					WHEN 1 THEN
					( SELECT EBMG_STANDARD_HOURS FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =( SELECT EBMG_PARENT_PM_CODE FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =? ) ) ELSE ( SELECT EBMG_STANDARD_HOURS FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =? ) 
				END 
				) AS EBMG_STANDARD_HOURS 
			FROM
				DUALSELECT (
				CASE
						( SELECT ( SELECT EBMG_STANDARD_HOURS FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =? ) IS NULL FROM DUAL ) 
						WHEN 1 THEN
						( SELECT EBMG_STANDARD_HOURS FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =( SELECT EBMG_PARENT_PM_CODE FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =? ) ) ELSE ( SELECT EBMG_STANDARD_HOURS FROM EB_MATERIAL_GROUP WHERE EBMG_CODE =? ) 
					END 
					) AS EBMG_STANDARD_HOURS 
			FROM
DUAL

1.4 调度波次生成或者添加任务系统异常

问题原因:地址里面有特殊字符,需要手动的将收货地址中的特殊字符去掉,例如空格,引号等

select * from et_task where ETTA_SO_NO = 'YXSA23042400007' and  ETTA_ETOR_FROM_EBRG_ADDRESS like '%"%';
select * from et_task where ETTA_ETOR_TO_EBRG_ADDRESS like '%"%'

ETTA_ETOR_FROM_EBRG_ADDRESS :发货地址
ETTA_ETOR_TO_EBRG_ADDRESS :收货地址

1.5 东鹏出库单部分出库回传之后要求重传

按照常理订单出入库回传之后不可再次回传,但是有些时候仓库要求帮助回传,执行方案如下

  • 1、根据需要回传的数量更新订单的出库数量
    在这里插入图片描述
    处理脚本为:
select * from eo_c_order_item where eooi_order_no = '物联单行';

更新 EOOI_ALLOCATED_QTY
在这里插入图片描述

将实发数量修改为需要回传的数量
千万注意:由于东鹏回传数量是累加的,因此这里的面数据需要修改为需要回传的数量,回传完成之后,EOOI_ALLOCATED_QTY需要修改为原来的值,如果有多条数据,但是不用回传的,可以暂时将无需回传的数据rec_status=1,等待回传完成之后,在修改rec_status=0

  • 第二步,操作回传

总订单查询->接口重传
在这里插入图片描述

1.6 更新订单商品分类

先更新订单商品分类编码
在更新分类名称

# 更新编码
update eo_c_order_item eooi set  
EOOI_ITEM_TYPE_CODE =  (select CDCM_TYPE_CODE from cd_common_material where cdcm_material_no = eooi_code limit 1) 
where eooi.CREATE_TIME>'2023-04-27'
select 
eooi.EOOI_ITEM_TYPE_CODE,
eooi.EOOI_ITEM_TYPE_NAME
from eo_c_order_item eooi
left join EB_MATERIAL_GROUP emg on eooi.EOOI_ITEM_TYPE_CODE = emg.EBMG_CODE
where eooi.CREATE_TIME>'2023-04-27' and emg.EBMG_CODE is null;

# 更新名称
update eo_c_order_item eooi set  
EOOI_ITEM_TYPE_NAME =  (select EBMG_NAME_CN from eb_material_group where EBMG_CODE = eooi.EOOI_ITEM_TYPE_CODE) 
where eooi.CREATE_TIME>'2023-04-27'

1.7 中心库存查询

select * from eo_virtual_inv_item where eovi_sku_code = 'jr000027853077' and color = ''

1.8 运输单全部任务已经签收,但是运输单仍是在途状态

select * from et_dispatch_order where ETDO_NO = 'T2305020000006';

需要修改运输单状态30->60

2.常用查询脚本

2.1 查看主数据,导出主数据

select 
jdo.code 居然商品编码,
jdo.string64 客户商品编码,
jdo.name 商品名称,
jdo.string66 客户组,
jdo.string65 品牌,
jdo.string22 是否定制品,
jdo.string17 大类编码,
jdo.string12 大类名称,
jdo.string18 中类编码,
jdo.string8 中类名称,
jdo.string19 小类编码,
jdo.string67 小类名称,
jdo.double1 长,
ebmg.EBMG_SUBSTR1 品类长推荐,
jdo.double2 宽,
ebmg.EBMG_SUBSTR2 品类宽推荐,
jdo.double3 高,
ebmg.EBMG_SUBSTR3 品类高推荐,
jdo.double10 体积,
ebmg.EBMG_SUBSTR4 品类体积推荐,
jdo.double4 重量,
jdo.double5 包装长,
jdo.double6 包装宽,
jdo.double7 包装高,
jdo.double8 包装体积,
jdo.double9 包装重量,
(select qty from jrwl_wms.wm_inv_lot_loc where SKU_CODE = `code` and qty>0 limit 1) 库存
from jr_data_object jdo
left join jr_eb_material_group ebmg on ebmg.EBMG_CODE = jdo.string19
where OBJECT_TYPE = 'SP' and DEL_FLAG = 0 and DATA_DISABLE = 0
# 新增三级分类条件
-- and ( ABS(ebmg.EBMG_SUBSTR1 + 0 -jdo.double1) > (ebmg.EBMG_SUBSTR1 + 0)*0.2 # 长宽高
-- or ABS(ebmg.EBMG_SUBSTR2 + 0 -jdo.double2) > (ebmg.EBMG_SUBSTR2 + 0)*0.2 # 长宽高
-- or ABS(ebmg.EBMG_SUBSTR3 + 0 -jdo.double3) > (ebmg.EBMG_SUBSTR3 + 0)*0.2 # 长宽高
-- or ABS(ebmg.EBMG_SUBSTR4 + 0 -jdo.double4) > (ebmg.EBMG_SUBSTR4 + 0)*0.2 # 体积)
-- or jdo.double1 is null or jdo.double1 =1
-- or jdo.double2 is null or jdo.double2 =1
-- or jdo.double3 is null or jdo.double3 =1
-- or jdo.double4 is null or jdo.double4 =1
-- )
-- limit  10

AND JDO.integer1 = 1
-- and code = 'jr000019719560';

2.2 导出三级分类

SELECT
	one.EBMG_CODE '一级分类编码',
	one.EBMG_NAME_CN '一级分类名称',
	two.EBMG_CODE '二级分类编码',
	two.EBMG_NAME_CN '二级分类名称',
	three.EBMG_CODE '三级分类编码',
	three.EBMG_NAME_CN '三级分类名称',
	IFNULL(three.EBMG_SUBSTR1,0) '品类长推荐',
	IFNULL(three.EBMG_SUBSTR2,0) '品类宽推荐',
	IFNULL(three.EBMG_SUBSTR3,0) '品类高推荐',
	IFNULL(three.EBMG_SUBSTR4,0) '品类体积推荐' 
FROM
	( SELECT * FROM jr_eb_material_group WHERE EBMG_LEVEL = 1 AND REC_STATUS < 1 AND EBMG_STATE = '0' ) one
	LEFT JOIN ( SELECT * FROM jr_eb_material_group WHERE EBMG_LEVEL = 2 AND REC_STATUS < 1 AND EBMG_STATE = '0' ) two ON one.EBMG_CODE = two.EBMG_PARENT_PM_CODE
	LEFT JOIN ( SELECT * FROM jr_eb_material_group WHERE EBMG_LEVEL = 3 AND REC_STATUS < 1 AND EBMG_STATE = '0' ) three ON two.EBMG_CODE = three.EBMG_PARENT_PM_CODE

2.3 查询回传失败脚本

详情可以参考报表:接口回传
在这里插入图片描述

select * from oms_interface_log where
SENDER = 'WMS'
and REMARK like '订单出库完成%'
and message not like '%成功%'
and message not like '%没有可转单据的行%'
and ORDER_NO in(
select
DISTINCT eoor.EOOR_ORDER_NO
from eo_c_order_item eooi
left join eo_c_order eoor on eoor.EOOR_ORDER_NO = eooi.EOOI_ORDER_NO
where eooi.eooi_code = 'jr000035695860' 
and eooi.REC_STATUS = 0 
and eoor.REC_STATUS = 0
and eoor.EOOR_STATUS_CODE not in ('00','500')
and eoor.EOOR_CUSTOMER_CODE = 'jr000523'
and eoor.EOOR_ORDER_TYPE_CODE in(
select EBCD_CODE from eb_code_master where EBCD_DICTIONARY_TYPE = 'OMS_NEW_OUT_ORDER_TYPE'
)
)

2.4 查询订单商品行号重复脚本

SELECT COUNT(EOOI_LINK_PM_CODE),EOOI_LINK_PM_CODE,EOOI_ORDER_NO  FROM eo_c_order_item eooi
			left join eo_c_order eoor on eoor.EOOR_ORDER_NO = eooi.EOOI_ORDER_NO
			where eoor.CREATE_TIME>'2023-01-01' and eoor.REC_STATUS = 0 and eooi.REC_STATUS = 0 and eoor.EOOR_STATUS_CODE <> '500'
			GROUP BY EOOI_LINK_PM_CODE,EOOI_ORDER_NO
			HAVING COUNT(EOOI_LINK_PM_CODE)>1

2.5 查询重复商品分类

## 查询数据
select count(*),ebmg_code from eb_material_group group by ebmg_code having count(*)>1

## 修复数据
select * from eb_material_group where ebmg_code = '0740021010';
select * from jrwl_mdm.jr_material_group limit 10;
select * from jrwl_mdm.JR_EB_MATERIAL_GROUP where EBMG_CODE = '0740021018';

3 程序修复类

3.1修复主数据

3.1.1修复主数据的商品分类

主数据分类修复,需要修复主数据的信息有

商品大类编码:string17
商品大类名称:string12
商品中类编码:string18
商品中类名称:string8
商品小类编码:string19
商品小类名称:string67
integer1默认为1标记人工修复过

命中的条件是居然商品编码jr编码,此编码全局唯一
更新表为 :jr_data_object

更新sql为:

update jr_data_object jdo set string17= '大类编码',jdo.string12 ='大类名称',jdo.string18 = '中类编码',jdo.string8 ='中类名称',jdo.string19 ='小类编码',jdo.string67 ='小类名称',integer1 = 1 where code = '商品编码'

以下是修复数据的主要代码
Mdm修复商品主类

@Slf4j
public class Mdm {
    // 读取excel
    public static void main(String[] args) throws IOException, SQLException, ClassNotFoundException {
        List<MdmSku> mdmSkus = readDatas();
        Connection connection = DataSource.getConnection("jdbc:mysql://地址:3306/数据库", "账号", "密码");
        ExecutorService executorService = Executors.newFixedThreadPool(20);

        String sql = "update jr_data_object jdo set string17= '大类编码',jdo.string12 ='大类名称',jdo.string18 = '中类编码',jdo.string8 ='中类名称',jdo.string19 ='小类编码',jdo.string67 ='小类名称',integer1 = 1 where code = '商品编码'";
        mdmSkus.forEach(sku->{
            String replace = sql.replace("商品编码", sku.getCode())
                    .replace("大类编码", sku.getTypeName1())
                    .replace("大类名称", sku.getTypeCode1())
                    .replace("中类编码", sku.getTypeName2())
                    .replace("中类名称", sku.getTypeCode2())
                    .replace("小类编码", sku.getTypeName3())
                    .replace("小类名称", sku.getTypeCode3());

            // log.info("执行SQL为:{}",replace);
            executorService.submit(new MdmSkuUpdateTread(connection,replace,sku.getCode()));
        });
        executorService.shutdown();
    }

    private static List<MdmSku> readDatas(){
        List<MdmSku> list = new ArrayList<>();
        Workbook workbook = null;
        try {
            workbook = new XSSFWorkbook(new FileInputStream("C:\\Work\\2023\\04\\26\\分类为其他的数据-4-25.xlsx"));
            Sheet updateSet = workbook.getSheet("更新数据");
            // 读取最总行数
            int lastRowNum = updateSet.getLastRowNum();
            for (int i=1;i<lastRowNum;i++){
                Row row = updateSet.getRow(i);
                MdmSku sku = new MdmSku();
                Cell cell0 = row.getCell(0);
                Cell cell1 = row.getCell(1);
                Cell cell2 = row.getCell(2);
                Cell cell3 = row.getCell(3);
                Cell cell4 = row.getCell(4);
                Cell cell5 = row.getCell(5);
                Cell cell6 = row.getCell(6);
                sku.setCode(cell0.getStringCellValue());
                sku.setTypeCode1(cell1.getStringCellValue());
                sku.setTypeName1(cell2.getStringCellValue());
                sku.setTypeCode2(cell3.getStringCellValue());
                sku.setTypeName2(cell4.getStringCellValue());
                sku.setTypeCode3(cell5.getStringCellValue());
                sku.setTypeName3(cell6.getStringCellValue());
                list.add(sku);
            }
            return list;
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }
}

读取excel的格式一定要按照一下顺序排列,从第0行开始读取
在这里插入图片描述
为了加快执行效率,以上代码使用多线程编写,线程类MdmSkuUpdateTread
主要的功能实在更新主数据的同时,下发的各个业务系统中去

@Slf4j
public class MdmSkuUpdateTread implements Runnable{
    private Connection connection;
    private String sql;
    private String code;
    
    public MdmSkuUpdateTread(Connection connection, String sql,String code) {
        this.connection = connection;
        this.sql = sql;
        this.code = code;
    }
    @Override
    public void run() {
        try {
            Statement statement = connection.createStatement();
            int update = statement.executeUpdate(sql);

            if(update < 1){
                log.error("sql执行失败:{}",sql);
            }else{
                // 请求数据;
                String querySql = "select id from jr_data_object where code = 'JRCODE' limit 1";
                ResultSet jrcode = statement.executeQuery(querySql.replace("JRCODE", code));
                while (jrcode.next()){
                    long id = jrcode.getLong("ID");

                    // 请求mdm下发;
                    // log.info("得到信息为:{}",id);
                    String url = "https://www.jrlog.cn/module-mdmweb/mdmweb/JrDataObject/sendData.shtml";

                    String content = "dataTypeId=DATAID&sendType=1&sendObj=&dataType=SP";

                    Map<String,String> headers = new HashMap<>();
                    headers.put("Content-Type","application/x-www-form-urlencoded; charset=UTF-8");
                    headers.put("Cookie","JSESSIONID=416871FE4424DF396B17A070496CE1A4; _sna=U1FRUVVRUFRVXVZdVlJTUlBHUVZXUVFHVVRUUVxWXFZHVVRUR0A7Cg0IO0BH");
                    headers.put("User-Agent","Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.127 Safari/537.36 Edg/100.0.1185.50");
                    String payload = content.replace("DATAID",id+"");
                    log.info("请求参数为:{}",payload);
                    String post = null;
                    try {
                        post = HttpURLConnectionUtil.post(url, payload, headers);
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                    log.info("请求结果为:{}",post);
                }
            }
            statement.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

需要注意的是这里的Cookie:需要根据实际替换

商品信息类 MdmSku

@Data
public class MdmSku {

    private String code;

    private String typeCode1;

    private String typeName1;

    private String typeCode2;

    private String typeName2;

    private String typeCode3;

    private String typeName3;

    private double length;

    private double width;

    private double hight;

    private double weight;

    private double volume;
}

3.2 修改主数据的长宽高体积重量并下发

和3.1的类似

@Slf4j
public class MdmVolumeWeight {

    public static void main(String[] args) throws SQLException, ClassNotFoundException {
        List<MdmSku> mdmSkus = readDatas();
        Connection connection = DataSource.getConnection("jdbc:mysql://地址:3306/数据库", "账号", "密码");
        ExecutorService executorService = Executors.newFixedThreadPool(20);
        // String sql = "update jr_data_object jdo set string17= '大类编码',jdo.string12 ='大类名称',jdo.string18 = '中类编码',jdo.string8 ='中类名称',jdo.string19 ='小类编码',jdo.string67 ='小类名称',integer1 = 1 where code = '商品编码'";

        String sql = "update jr_data_object jdo set  " +
                "jdo.double1 =长 , " +
                "jdo.double2 =宽, " +
                "jdo.double3 =高, " +
                "jdo.double10 =体积," +
                "jdo.double4 =重量," +
                "jdo.double5 =长," +
                "jdo.double6 =宽," +
                "jdo.double7 =高," +
                "jdo.double8 =体积," +
                "jdo.double9 =重量," +
                "jdo.string33='1'" +
                "where jdo.code='商品编码'";

        mdmSkus.forEach(sku->{
            String replace = sql.replace("商品编码", sku.getCode())
                    .replace("长", sku.getLength()+"")
                    .replace("宽", sku.getWidth()+"")
                    .replace("高", sku.getHight()+"")
                    .replace("体积", sku.getVolume()+"")
                    .replace("重量", sku.getWeight()+"");

            //log.info("执行SQL为:{}",replace);
            //log.info("");
            executorService.submit(new MdmSkuUpdateTread(connection,replace,sku.getCode()));
        });
        executorService.shutdown();

        // connection.close();
    }
    private static List<MdmSku> readDatas() {

        List<MdmSku> list = new ArrayList<>();

        Workbook workbook = null;
        try {
            workbook = new XSSFWorkbook(new FileInputStream("C:\\Work\\2023\\04\\26\\鑫德需改尺寸.xlsx"));
            Sheet updateSet = workbook.getSheet("更新数据");

            // 读取最总行数
            int lastRowNum = updateSet.getLastRowNum();

            for (int i=1;i<lastRowNum;i++){
                Row row = updateSet.getRow(i);
                MdmSku sku = new MdmSku();

                Cell cell0 = row.getCell(0);
                Cell cell1 = row.getCell(1);
                Cell cell2 = row.getCell(2);
                Cell cell3 = row.getCell(3);
                Cell cell4 = row.getCell(4);
                Cell cell5 = row.getCell(5);

                sku.setCode(cell0.getStringCellValue());
                sku.setLength(cell1.getNumericCellValue());
                sku.setWidth(cell2.getNumericCellValue());
                sku.setHight(cell3.getNumericCellValue());
                sku.setWeight(cell4.getNumericCellValue());
                sku.setVolume(cell5.getNumericCellValue());
                list.add(sku);
            }
            return list;
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }
}

excel格式要求
sheet名称:数据更新
在这里插入图片描述
更新线程类 MdmSkuUpdateTread 与3.1公用

3.3 订单签收状态重传

订单签收状态重传之前需要确认重传是否会影响到对方系统的状态,例如退货单状态是否会从已入库状态变更为已签收状态,如果没有这样的影响则可以回传;

选中需要重传单据SQL:

select ETTA_EXTERNAL_ORDER_NO from et_task where CREATE_TIME>'2023-04-06' and ETTA_CUSTOM_EBCU_NO = '客户编码' and  ETTA_STATUS = '90' and REC_STATUS = 0

主程序代码FeedBack

public class FeedBack {

    public static void main(String[] args) throws SQLException, ClassNotFoundException {
        // 从数据库里面选择单据
        String sql = "select ETTA_EXTERNAL_ORDER_NO from et_task where CREATE_TIME>'2023-04-06' and ETTA_CUSTOM_EBCU_NO = 'jr000494' and  ETTA_STATUS = '90' and REC_STATUS = 0";

        Connection connection = DataSource.getConnection("jdbc:mysql://地址:3306/数据库", "账号", "密码");

        PreparedStatement preparedStatement = connection.prepareStatement(sql);

        ResultSet resultSet = preparedStatement.executeQuery();

        ExecutorService executorService = Executors.newFixedThreadPool(1);

        while(resultSet.next()){
            String etta_external_order_no = resultSet.getString("ETTA_EXTERNAL_ORDER_NO");
            executorService.submit(new StatusFeedbackThread(etta_external_order_no,"55","订单运输任务已全部签收!"));
        }
        executorService.shutdown();
    }
}

更新线程:StatusFeedbackThread

public class StatusFeedbackThread implements Runnable{

    private String orderNo;

    private String status;

    private String label;

    public StatusFeedbackThread(String orderNo, String status, String label) {
        this.orderNo = orderNo;
        this.status = status;
        this.label = label;
    }


    @Override
    public void run() {
        String url = "https://www.jrlog.cn/module-oms2cweb/oms2cweb/eorder/eorderManager/rePushOrderStatus.shtml";

        String content = "eoorOrderNo="+orderNo+"&statusCode="+status+"&statusName="+label;
        Map<String,String> headers = new HashMap<>();
        headers.put("Content-Type","application/x-www-form-urlencoded; charset=UTF-8");
        headers.put("Cookie","JSESSIONID=B87A417F5CF2C7C852621DA357C3EAF7; _sna=U1FRUVVRUFRVXVZdVlJTUlBHUVZXUVFHVVRUUVxWXFZHVVRUR0A7Cg0IO0BH");
        headers.put("User-Agent","Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.127 Safari/537.36 Edg/100.0.1185.50");
        // String payload = content.replace("DATAID",id+"");
        log.info("请求参数为:{}",content);
        String post = null;
        try {
            post = HttpURLConnectionUtil.post(url, content, headers);
        } catch (IOException e) {
            e.printStackTrace();
        }
        log.info("请求结果为:{}",post);
    }
}

还是一样Cookie需要修改一下

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/485407.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

表情符号(emoji)大全,只此一文便够了

本文由 大侠(AhcaoZhu)原创&#xff0c;转载请声明。 链接: https://blog.csdn.net/Ahcao2008 表情符号&#xff08;emoji&#xff09;大全、只此一文便够了 摘要集中展示笑脸和动物人庆贺和物品食品和物交通和地点符号 符号表smileys_and_peopleanimals_and_naturefood_and_dr…

Spring Boot集成ShardingSphere实现数据分片(三) | Spring Cloud 42

一、前言 在前面我们通过以下章节对数据分片有了基础的了解&#xff1a; Spring Boot集成ShardingSphere实现数据分片&#xff08;一&#xff09; | Spring Cloud 40 Spring Boot集成ShardingSphere实现数据分片&#xff08;二&#xff09; | Spring Cloud 41 知道数据分片…

Sentinel --- 简介、流量控制

一、Sentinel 1.1、雪崩问题及解决方案 雪崩问题 微服务中&#xff0c;服务间调用关系错综复杂&#xff0c;一个微服务往往依赖于多个其它微服务。 如图&#xff0c;如果服务提供者I发生了故障&#xff0c;当前的应用的部分业务因为依赖于服务I&#xff0c;因此也会被阻塞。此…

Spring AOP(重点、难点)

Spring AOP&#xff08;重点、难点&#xff09; 文章目录 Spring AOP&#xff08;重点、难点&#xff09;1.aop引入1.1 使用场景与概念引入1.2 以数据校验记录操作日志为例 写一组代码进行递推初始阶段 老老实实一个一个写&#xff1a;阶段一 **将日志和验证方法包装到一个类里…

海洋测绘设备使用总结快讯(2023年5月)

本文主要记录最近海洋测绘设备使用过程中遇到一些小问题和解决方法。 1、侧扫声纳绞车的事情 从去年10月到今年3月一直有一个困扰我们的问题&#xff1a;我们侧扫声纳的铠装缆在租用广西北海渔船且用发电机发电的情况下&#xff0c;能连接Klein3000和Klein4000拖鱼&#xff0…

通过Date类学习面向对象

通过手撸这个类的实现&#xff0c;我们可以学习到构造、析构、运算符重载&#xff0c;拷贝构造等面向对象中重要的知识。 首先先看头文件中类的定义&#xff1a; class Date { public:// 获取某年某月的天数int GetMonthDay(int year, int month);// 全缺省的构造函数Date(in…

算法的时间复杂度和空间复杂度(友友们专属限定版)

&#x1f349;博客主页&#xff1a;阿博历练记 &#x1f4d6;文章专栏&#xff1a;数据结构与算法 &#x1f69a;代码仓库&#xff1a;阿博编程日记 &#x1f339;欢迎关注&#xff1a;欢迎友友们点赞收藏关注哦 文章目录 &#x1f3a8;1.算法的复杂度介绍&#x1f3a8;2.时间复…

坤强服务器安装

记录一下服务器安装做raid和安装系统 raid 0 拆分开分别存在3块硬盘,一块坏了,全部不能用了, 但是存储速度最快 raid 1 具有最高的安全性,备份一份,容量只有总容量的一半 raid 10 先组两个raid1,再组两个raid0 .有raid 1的安全性和50%的使用容量 raid 5 安全性&#xff…

汇编二、51单片机内部结构

1、单片机内部资源 以AT89C51单片机为例&#xff0c;参考数据手册。 Atmel官网&#xff1a; https://www.microchip.com/ (1)1个8位CPU。 (2)4K ROM&#xff0c;128字节RAM。 (3)32个GPIO&#xff1b;定时器(Timer)&#xff1b;串口(UART)&#xff1b;中断系统(Interrupt…

Qt之滑动条和进度条(QSlider、QProgressBar)

文章目录 前言一、QSliderQSlider的常用API信号与槽 二、QProgressBar滑动条和滚动条的常用API 总结 前言 在用户界面设计中&#xff0c;滑动条和进度条是常见的控件。Qt中提供了QProgressBar和QSlider两个类来实现滚动条和滑动条。 一、QSlider 在Qt中&#xff0c;QSlider是…

ChatGPT攥写广告文案-写好广告营销软文的必备要点

chatgpt帮助我们写营销软文 Chat GPT是一款强大的自然语言处理模型&#xff0c;可以辅助您编写优秀的营销软文。下面是几个使用 Chat GPT 更好的编写营销软文的建议&#xff1a; 利用Chat GPT自动摘要 Chat GPT能够将一段较长的营销文本精简成几个关键点&#xff0c;这有利于…

32. 最长有效括号

32. 最长有效括号 难度困难2251 给你一个只包含 ( 和 ) 的字符串&#xff0c;找出最长有效&#xff08;格式正确且连续&#xff09;括号子串的长度。 示例 1&#xff1a; 输入&#xff1a;s "(()" 输出&#xff1a;2 解释&#xff1a;最长有效括号子串是 "…

《C语言技术体系》 学习路线总目录 + 思维导图

目录 前言 正文 思维导图 第1章 流程结构 1.1 初识C语言 1.2 流程结构 1.3 数据类型 1.4 运算符表达式 第2章 指针与数组 2.1 指针基本概念 2.2 一维数组 2.3 二维及多维数组 2.4 指针与数组 第3章 模块化重构 3.1 函数 3.2 typedef类型定义 3.3 enum枚举 3.…

手把手教你使用vue2搭建微前端micro-app

​ 简述 本文主要讲述新手小白怎么搭建micro-app&#xff0c;几乎是每一步都有截图说明。上手应该很简单。 本来我之前已经写了一篇手把手教程了&#xff0c;但是当时写的结个太乱了&#xff0c;趁着五一休假&#xff0c;重新整理了一番&#xff0c;加了文章目录&#xff0c;…

如何显示文件夹的后缀和隐藏文件

© Ptw-cwl 文章目录 前言文件夹后缀隐藏文件 如何设置显示文件夹的后缀和隐藏文件 前言 文件夹后缀 文件后缀是指文件名中最后一个“.”后面的一串字符&#xff0c;用来表示该文件的类型或格式。不同的文件类型有不同的后缀&#xff0c;例如&#xff0c;常见的图片文件…

对象浅拷贝的5种方式

参考原文:浅拷贝的五种实现方式 - 掘金 (juejin.cn) 哈喽 大家好啊 最近发现自己对对象都不是很熟练&#xff0c;特别是涉及到一些复制&#xff0c;深浅拷贝的东西 1.Object.assign 首先 我们创建一个空对象obj1 然后创建一个对象obj2 用object.assign(目标对象&#xff0c…

庖丁解牛函数知识---C语言《2》

目录 前言&#xff1a; 1.嵌套调用函数 2.链式访问 3.函数的声明与定义 4.*递归 5.递归与非递归 ❤博主CSDN:啊苏要学习 ▶专栏分类&#xff1a;C语言◀ C语言的学习&#xff0c;是为我们今后学习其它语言打好基础&#xff0c;C生万物&#xff01; 开始我们的C语言之旅吧…

C6678学习-GPIO

文章目录 1、简介2、框图3、寄存器4、地址 1、简介 C6678中共有16个GPIO&#xff0c;GPIO0~GPIO15。这些引脚的功能如下 ​ 通用输入输出管脚​ 中断&EDMA事件管脚 2、框图 1、GPIO作为通用输入输出时&#xff0c;用到的寄存器为DIR、SET_DATA、OUT_DATA、CLR_DATA、IN_…

AI奇点已至,是黎明前的黑暗,还是黑夜前的黄昏

2022年11月&#xff0c;OPEN AI公司推出了ChatGPT 3模型&#xff0c;瞬间引爆全球话题&#xff0c;所有业内人士都在感叹他的强大&#xff0c;比尔盖茨也曾经评价道&#xff0c;ChatGPT将会改变世界 &#xff0c;是一个相当于PC和互联网的革命性产品。 作为信息行业人&#xff…

网络请求与远程资源

网络请求与远程资源 网络分层 一、OSI七层模型、TCP/IP概念层模型 区别&#xff1a;OSI模型注重通信协议必要的功能是什么&#xff0c;TCP/IP模型更强调在计算机上实现协议应该开发哪种程序。 二、应用层的网络协议 FTP&#xff1a;文本传输协议SMTP&#xff1a;简单邮件传输协…