java开发记录-微信二维码支付

2023-11-02

关于微信二维码支付的一点点总结.如上一个博客所说,开始开发前需要前往官网进行一系列的接入,从而得到相关的appid,密钥.

本次的开发中,使用谷歌zxing实现将支付链接字符串转为二维码.附上相关依赖:

<!-- 谷歌生成二维码 -->
<dependency>
    <groupId>com.google.zxing</groupId>
    <artifactId>core</artifactId>
    <version>3.3.0</version>
</dependency>
<dependency>
    <groupId>com.google.zxing</groupId>
    <artifactId>javase</artifactId>
    <version>3.3.0</version>
</dependency>

1.PayUtils工具类

    和之前微信H5支付类似,只是将其中的支付类型trade_type修改为NATIVE,代码如下:

public class PayUtils {
	/**
	 * 公众号AppId
	 */
	public static final String APP_ID = "xxx";
	/**
	 * 公众号AppSecret
	 */
	public static final String APP_SECRET = "xxx";
	/**
	 * 微信支付商户号
	 */
	public static final String MCH_ID = "xxx";
	/**
	 * 微信支付API秘钥
	 */
	public static final String KEY = "xxx";
	/**
	 * 回调域名
	 */
	public static final String REDIRECT_DOMAIN = "http://xxx.com";

	private static final WxMpService wxMpService = new WxMpServiceImpl();
	private static final WxPayService wxPayService = new WxPayServiceImpl();

	static {
		WxMpInMemoryConfigStorage config = new WxMpInMemoryConfigStorage();
		config.setAppId(APP_ID);
		config.setSecret(APP_SECRET);
		wxMpService.setWxMpConfigStorage(config);

		WxPayConfig payConfig = new WxPayConfig();
		payConfig.setAppId(APP_ID);
		payConfig.setMchId(MCH_ID);
		payConfig.setMchKey(KEY);
		payConfig.setSignType(WxPayConstants.SignType.MD5);
		//二维码支付
		payConfig.setTradeType("NATIVE");
		payConfig.setNotifyUrl(REDIRECT_DOMAIN + "/pay/success");
		wxPayService.setConfig(payConfig);
	}

	public static WxMpService wxMpService() {
		return wxMpService;
	}

	public static WxPayService wxPayService() {
		return wxPayService;
	}

}

需要注意的是,在接下来的controller设计中,tradeType值为NATIVE时,微信统一下单接口的prodectId是必填的.

2.后台controller

	/**
	 * 首页
	 */
	@RequestMapping(value = "/index")
	public String index(Model model) {
		String qrcodePayUrl = PayUtils.REDIRECT_DOMAIN+"/pay/qrcodePay";
		model.addAttribute("qrcodePay",qrcodePayUrl);

		String downloadQRCode = PayUtils.REDIRECT_DOMAIN+"/pay/downloadQRCode";
		model.addAttribute("downloadQRCode",downloadQRCode);
		return "index";
	}


	/**
	 * 点击链接跳转显示支付二维码
	 * @param request
	 * @param response
	 * @param model
	 */
	@RequestMapping(value = "/qrcodePay")
	public void qrcodePay(HttpServletRequest request,HttpServletResponse response,Model model){
		try {
			//统一订单必填参数
			WxPayUnifiedOrderRequest orderRequest = new WxPayUnifiedOrderRequest();
			orderRequest.setBody("微信二维码支付测试");
			orderRequest.setOutTradeNo(UUID.randomUUID().toString().replace("-", ""));
			orderRequest.setTotalFee(1);
			//用户ip
			orderRequest.setSpbillCreateIp(getRealIp(request));
			//商品ID 二维码支付时必填
			orderRequest.setProductId(UUID.randomUUID().toString().replace("-", ""));
			//签名创建
			Map<String,String> packageParams = new HashMap<>();
			packageParams.put("appid", PayUtils.APP_ID);
			packageParams.put("mch_id", PayUtils.MCH_ID);
			packageParams.put("nonce_str", UUID.randomUUID().toString().replace("-", ""));
			packageParams.put("signType",orderRequest.getSignType());
			String sign = SignUtils.createSign(packageParams,"MD5", PayUtils.KEY,false);
			orderRequest.setSign(sign);

			WxPayNativeOrderResult orderResult =  PayUtils.wxPayService().createOrder(orderRequest);
			String codeUrl = orderResult.getCodeUrl();

			QRcodeImageUtil.encode(codeUrl,300,300,getIconUrl(),null,false,response);
		} catch (WxPayException e) {
			e.printStackTrace();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	/**
	 * 直接在页面上显示支付二维码
	 * @param request
	 * @return
	 */
	@RequestMapping("/downloadQRCode")
	public ResponseEntity<byte[]> downloadQRCode(HttpServletRequest request){
		try{
			//统一订单必填参数
			WxPayUnifiedOrderRequest orderRequest = new WxPayUnifiedOrderRequest();
			orderRequest.setBody("微信二维码支付测试");
			orderRequest.setOutTradeNo(UUID.randomUUID().toString().replace("-", ""));
			orderRequest.setTotalFee(1);
			//用户ip
			orderRequest.setSpbillCreateIp(getRealIp(request));
			//商品ID 二维码支付时必填
			orderRequest.setProductId(UUID.randomUUID().toString().replace("-", ""));
			//签名创建
			Map<String,String> packageParams = new HashMap<>();
			packageParams.put("appid", PayUtils.APP_ID);
			packageParams.put("mch_id", PayUtils.MCH_ID);
			packageParams.put("nonce_str", UUID.randomUUID().toString().replace("-", ""));
			packageParams.put("signType",orderRequest.getSignType());
			String sign = SignUtils.createSign(packageParams,"MD5", PayUtils.KEY,false);
			orderRequest.setSign(sign);

			WxPayNativeOrderResult orderResult =  PayUtils.wxPayService().createOrder(orderRequest);
			String codeUrl = orderResult.getCodeUrl();

			return QRcodeImageUtil.getResponseEntity(codeUrl,300,300,"png",getIconUrl());
		}catch (Exception e){
			e.printStackTrace();
		}
		return null;
	}

	//获取真实ip地址 通过阿帕奇代理的也能获取到真实ip
	private static String getRealIp(HttpServletRequest request){
		String ip = request.getHeader("x-forwarded-for");
		if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)){
			ip = request.getHeader("Proxy-Client-IP");
		}
		if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)){
			ip = request.getHeader("WL-Proxy-Client-IP");
		}
		if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)){
			ip = request.getRemoteAddr();
		}
		return ip;
	}

	/**
	 * 获取二维码中心图标再项目中的地址
	 * @return
	 */
	private static String getIconUrl(){
		ClassLoader classLoader = PayUtils.class.getClassLoader();
		URL resource = classLoader.getResource("");
		String icon = resource.getPath();
		//target/classes/下的图片无法使用,所以将其截取掉,并自主拼接好src下的图片位置
		icon = icon.substring(0,icon.length()-15);
		icon = icon +"/src/main/resources/public/image/bg.jpg";
		return icon;
	}

这里的getIconUrl()是获取项目中图片的方法,之前通过获取classes下的图片,发现不能嵌套到二维码中,具体原因还不清楚,若有大神知道,望指点.

3.zxing工具类

关于zxing的使用方法,我也是从别的博主那找来的方法,对其中的方法进行了一点点修改,还没有进行总结归纳,不过忘记那位博主的地址了=_=...直接附代码吧.

package com.novice.project.wxpay.utils;

import com.google.zxing.BarcodeFormat;
import com.google.zxing.EncodeHintType;
import com.google.zxing.MultiFormatWriter;
import com.google.zxing.WriterException;
import com.google.zxing.common.BitMatrix;
import com.google.zxing.qrcode.decoder.ErrorCorrectionLevel;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;

import javax.imageio.ImageIO;
import javax.servlet.http.HttpServletResponse;
import java.awt.*;
import java.awt.geom.AffineTransform;
import java.awt.image.AffineTransformOp;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

public class QRcodeImageUtil {
	/**
	 * 图片格式定义
	 * @value Array
	 */
	private static String[] IMAGE_TYPE = {"BMP", "bmp", "jpg", "JPG", "wbmp", "jpeg", "png", "PNG", "JPEG", "WBMP", "GIF", "gif","ICON","icon"};

	/**
	 * 二维码宽度
	 */
	public static final int WIDTH = 260;

	/**
	 * 二维码高度
	 */
	public static final int HEIGHT = 260;

	/**
	 * 图标宽度
	 */
	private static final int IMAGE_WIDTH = 68;
	/**
	 * 图标高度
	 */
	private static final int IMAGE_HEIGHT = 68;
	/**
	 * 底图大小【正方形】
	 */
	private static final int IMAGE_HALF_WIDTH = IMAGE_WIDTH / 2;
	/**
	 * 底图边框
	 */
	private static final int FRAME_WIDTH = 5;

	/**
	 * 二维码写码器
	 */
	private static MultiFormatWriter mutiWriter = new MultiFormatWriter();

	/**
	 * 二维码生成-方法入口
	 * @param content 内容
	 * @param width 宽度
	 * @param height 高度
	 * @param iconImagePath 图标原路径
	 * @param qrcodeImagePath 二维码存放路径
	 * @param hasFiller
	 *             比例不对时是否需要补白:true为补白; false为不补白
	 * @return
	 *         成功:返回输出图片绝对路径;失败:返回null
	 */
	public static String encode(String content, int width, int height,
	                            String iconImagePath, String qrcodeImagePath, boolean hasFiller, HttpServletResponse response) {
		try {
			/**
			 * 图标格式校验
			 */
			File icon = new File(iconImagePath);
			if(!icon.exists()){
				System.err.println("系统找不到图标所在文件 !");
				return null;
			}
			String iconFileName = icon.getName();
			// 得到上传文件的扩展名
			String fileExtName = iconFileName.substring(iconFileName.lastIndexOf(".") + 1);
			if(!checkIMGType(fileExtName)){
				System.err.println("图标格式有误 !");
				return null;
			}

			if(width<260||height<260){
				width = QRcodeImageUtil.WIDTH;
				height = QRcodeImageUtil.HEIGHT;
			}
			if(qrcodeImagePath!=null){
				ImageIO.write(genBarcode(content, width, height, iconImagePath,hasFiller),
						"png", new File(qrcodeImagePath));
				System.err.println("二维码已生成  "+qrcodeImagePath);
			}else{
				ImageIO.write(genBarcode(content, width, height, iconImagePath, hasFiller),
						"png", response.getOutputStream());
			}
			return qrcodeImagePath;
		} catch (IOException e) {
			System.err.println("图片读取异常 : "+e.getMessage());
		} catch (WriterException e) {
			System.err.println("图片输出异常 :"+e.getMessage());
		}
		return null;
	}

	/**
	 * 图片处理方法
	 * @param content
	 * @param width
	 * @param height
	 * @param iconImagePath
	 * @param hasFiller
	 *             比例不对时是否需要补白:true为补白; false为不补白;
	 * @return
	 * @throws WriterException
	 * @throws IOException
	 */
	private static BufferedImage genBarcode(String content, int width,
	                                        int height, String iconImagePath,boolean hasFiller) throws WriterException,
			IOException {
		// 读取源图像
		BufferedImage scaleImage = scale(iconImagePath, IMAGE_WIDTH,
				IMAGE_HEIGHT, hasFiller);
		int[][] srcPixels = new int[IMAGE_WIDTH][IMAGE_HEIGHT];
		for (int i = 0; i < scaleImage.getWidth(); i++) {
			for (int j = 0; j < scaleImage.getHeight(); j++) {
				srcPixels[i][j] = scaleImage.getRGB(i, j);
			}
		}

		Map<EncodeHintType, Object> hint = new HashMap<EncodeHintType, Object>();
		hint.put(EncodeHintType.CHARACTER_SET, "utf-8");
		hint.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.H);
		// 生成二维码
		BitMatrix matrix = mutiWriter.encode(content, BarcodeFormat.QR_CODE,
				width, height, hint);

		// 二维矩阵转为一维像素数组
		int halfW = matrix.getWidth() / 2;
		int halfH = matrix.getHeight() / 2;
		int[] pixels = new int[width * height];

		for (int y = 0; y < matrix.getHeight(); y++) {
			for (int x = 0; x < matrix.getWidth(); x++) {
				// 读取图片
				if (x > halfW - IMAGE_HALF_WIDTH
						&& x < halfW + IMAGE_HALF_WIDTH
						&& y > halfH - IMAGE_HALF_WIDTH
						&& y < halfH + IMAGE_HALF_WIDTH) {
					pixels[y * width + x] = srcPixels[x - halfW
							+ IMAGE_HALF_WIDTH][y - halfH + IMAGE_HALF_WIDTH];
				}
				// 在图片四周形成边框
				else if ((x > halfW - IMAGE_HALF_WIDTH - FRAME_WIDTH
						&& x < halfW - IMAGE_HALF_WIDTH + FRAME_WIDTH
						&& y > halfH - IMAGE_HALF_WIDTH - FRAME_WIDTH && y < halfH
						+ IMAGE_HALF_WIDTH + FRAME_WIDTH)
						|| (x > halfW + IMAGE_HALF_WIDTH - FRAME_WIDTH
						&& x < halfW + IMAGE_HALF_WIDTH + FRAME_WIDTH
						&& y > halfH - IMAGE_HALF_WIDTH - FRAME_WIDTH && y < halfH
						+ IMAGE_HALF_WIDTH + FRAME_WIDTH)
						|| (x > halfW - IMAGE_HALF_WIDTH - FRAME_WIDTH
						&& x < halfW + IMAGE_HALF_WIDTH + FRAME_WIDTH
						&& y > halfH - IMAGE_HALF_WIDTH - FRAME_WIDTH && y < halfH
						- IMAGE_HALF_WIDTH + FRAME_WIDTH)
						|| (x > halfW - IMAGE_HALF_WIDTH - FRAME_WIDTH
						&& x < halfW + IMAGE_HALF_WIDTH + FRAME_WIDTH
						&& y > halfH + IMAGE_HALF_WIDTH - FRAME_WIDTH && y < halfH
						+ IMAGE_HALF_WIDTH + FRAME_WIDTH)) {
					pixels[y * width + x] = 0xfffffff;
				} else {
					// 此处可以修改二维码的颜色,可以分别制定二维码和背景的颜色;
					pixels[y * width + x] = matrix.get(x, y) ? 0xff000000
							: 0xfffffff;
				}
			}
		}

		BufferedImage image = new BufferedImage(width, height,
				BufferedImage.TYPE_INT_RGB);
		image.getRaster().setDataElements(0, 0, width, height, pixels);

		return image;
	}

	/**
	 * 把传入的原始图像按高度和宽度进行缩放,生成符合要求的图标
	 *
	 * @param iconImagePath
	 *            小图标源文件地址
	 * @param height
	 *            目标高度
	 * @param width
	 *            目标宽度
	 * @param hasFiller
	 *            比例不对时是否需要补白:true为补白; false为不补白;
	 * @throws IOException
	 */
	private static BufferedImage scale(String iconImagePath, int height,
	                                   int width, boolean hasFiller) throws IOException {
		double ratio = 0.0; // 缩放比例
		File file = new File(iconImagePath);
		BufferedImage srcImage = ImageIO.read(file);
		Image destImage = srcImage.getScaledInstance(width, height,
				BufferedImage.SCALE_SMOOTH);
		// 计算比例
		if ((srcImage.getHeight() > height) || (srcImage.getWidth() > width)) {
			if (srcImage.getHeight() > srcImage.getWidth()) {
				ratio = (new Integer(height)).doubleValue()
						/ srcImage.getHeight();
			} else {
				ratio = (new Integer(width)).doubleValue()
						/ srcImage.getWidth();
			}
			AffineTransformOp op = new AffineTransformOp(
					AffineTransform.getScaleInstance(ratio, ratio), null);
			destImage = op.filter(srcImage, null);
		}
		if (hasFiller) {// 补白
			BufferedImage image = new BufferedImage(width, height,
					BufferedImage.TYPE_INT_RGB);
			Graphics2D graphic = image.createGraphics();
			graphic.setColor(Color.white);
			graphic.fillRect(0, 0, width, height);
			if (width == destImage.getWidth(null))
				graphic.drawImage(destImage, 0,
						(height - destImage.getHeight(null)) / 2,
						destImage.getWidth(null), destImage.getHeight(null),
						Color.white, null);
			else
				graphic.drawImage(destImage,
						(width - destImage.getWidth(null)) / 2, 0,
						destImage.getWidth(null), destImage.getHeight(null),
						Color.white, null);
			graphic.dispose();
			destImage = image;
			System.err.println("INFO 图标补白已完成 ");
		}
		return (BufferedImage) destImage;
	}

	/**
	 * 图片格式校验
	 * @param fileExtName
	 * @return
	 */
	private static boolean checkIMGType(String fileExtName){
		boolean flag = false;
		for (String type : IMAGE_TYPE) {
			//-- 图片格式正确
			if(type.toLowerCase().equals(fileExtName.toLowerCase())){
				flag = true;
				break;
			}
		}
		//------------图片格式校验结束
		return flag;
	}

	/**
	 * 生成并下载二维码
	 * @param content
	 * @param width
	 * @param height
	 * @param format
	 * @param imgPath
	 * @return
	 */
	public static ResponseEntity<byte[]> getResponseEntity(String content,int width,int height,String format,String imgPath){
		try {
			ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
			ImageIO.write(genBarcode(content,width,height,imgPath,false),format,outputStream);
			HttpHeaders headers = new HttpHeaders();
			headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);
			return new ResponseEntity<byte[]>(outputStream.toByteArray(),headers, HttpStatus.CREATED);
		} catch (Exception e) {
			e.printStackTrace();
		}
		return null;
	}

}

4.前台显示

<!DOCTYPE HTML>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <meta name="x5-orientation" content="portrait">
    <title>微信二维码支付测试</title>
</head>
<body>
<div id="container">
    <a th:href="${qrcodePay}" style="font-size:40px;">
        二维码支付
    </a><br>
    <img th:src="${downloadQRCode}">
</div>
</body>
</html>

前台使用thymeleaf进行前后数据绑定,你也可以使用自己的方式.这里仅仅是一个参考.微信的公众号/H5/二维码支付demo也会提供.

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

java开发记录-微信二维码支付 的相关文章

  • Objective-C 相当于 Java 枚举或“静态最终”对象

    我试图找到一个与 Java 枚举类型或 public static final 对象等效的 Objective C 例如 public enum MyEnum private String str private int val FOO f
  • 使用 Hibernate 用瞬态对象更新持久对象

    每天 数据都是通过网络服务导入的 我创建一个新的 暂时的 实例我通过 JPA 注释在 hibernate 中映射的 pojo 的 我将数据从 Web 服务填充到瞬态实例中 我从数据库加载持久对象 我想用瞬态实例中的数据更新该持久对象 我以某
  • 可序列化对象的 ArrayList 的加密保存和解密加载

    我在 SD 卡中保存并加载一个文件 其中包含ArrayList使用这两种方法的可序列化对象 保存方法 public static void saveUserList ArrayList
  • 仅运行相应源代码已更改的单元测试?

    我正在 Jenkins CI 服务器中运行单元测试和 Selenium 测试 众所周知 在大型项目中测试需要很长时间才能运行 Java 是否有一个工具 框架只能触发其源代码已更改的测试 这是因为并非每次对 SCM 的提交都会影响源代码的所有
  • 序列化 ArrayList

    我正在尝试编写一个 Android 游戏 即使用户想要返回主菜单或者活动被系统终止 我也希望能够暂停游戏 onSaveInstanceState 似乎并没有给我很大的控制权来决定何时可以读回捆绑包 而且据我所知 捆绑包仅在短时间内有效 所以
  • 如何打印JTable中选定的行

    我尝试使用主 JTable 的选定行和相同的头和单元格渲染来创建临时 JTable 但是当我尝试打印它时 我只得到一个带有线边框的空矩形 我在如何打印 JTable 的特定行 列 https stackoverflow com questi
  • 将 java 方法参数设置为最终参数

    那有什么区别final在下面的代码之间进行 将参数声明为有什么好处final public String changeTimezone Timestamp stamp Timezone fTz Timezone toTz return pu
  • 带嵌入式 tomcat 的 spring-boot 不会将请求分派到控制器

    我有一个使用 spring boot 和嵌入式 Tomcat 容器的应用程序 据我所知 我的代码与 spring boot 相同示例项目 https github com spring projects spring boot tree m
  • Byte[] 和 java.lang.OutOfMemoryError 按位读/写文件

    我正在努力擦除 Android 中的一些可用空间 这是我的代码 private void creatingFileDelete int size int passMode File lastFile new File Environment
  • Android Fabric Crashlytics 崩溃,初始化时未找到资源

    我从 google play 控制台收到了这份报告 看起来 Fabric 在启动时崩溃了 因为某些用户出现了资源未找到的异常 java lang RuntimeException at android app ActivityThread
  • 如何使用Gson将JSONArray转换为List?

    在我的 Android 项目中 我试图将收到的 JSONArray 转换为列表 在 的帮助下这个答案 https stackoverflow com questions 8371274 how to parse json array in
  • 字符串 a == 字符串 b 的规则 [重复]

    这个问题在这里已经有答案了 我试图了解字符串池的工作原理以及一个字符串等于另一个字符串的规则是什么 例如这个片段 public static void main String hi String s1 lol String s2 lol S
  • 相对重力

    我最近开始使用jMonkey引擎 这非常好 但我在尝试实现相对重力时陷入了困境 我想让行星彼此围绕轨道运行 不一定是完美的圆形轨道 取决于速度 所以每个对象都应该影响其他对象 我现在拥有的 关闭全球重力 bulletAppState get
  • java springrabbit - 优雅地拒绝消息

    我有以下侦听器方法 Override public void onMessage Message message Channel channel try do something bad catch Exception e try long
  • 更改JavaFX TableView字体大小[重复]

    这个问题在这里已经有答案了 您好 我想在表视图列内的文本上设置字体 我如何用 Java 做到这一点 这是我的代码 感谢帮助 private final TableView
  • 用二进制数、常规数字和格雷编码填充矩阵

    我有一个包含 1 s 或 0 s 的矩阵 用于创建二进制数 其宽度为n 对于 n 2 和 n 3 它看起来像 00 000 01 001 10 010 11 011 100 101 110 111 等等 现在我正在使用以下代码来生成它 in
  • SFTP Java - 管道关闭 Jsch 异常

    我正在研究一种 java 方法 将文件从一个位置复制到另一个远程位置 我的代码如下 我尝试使用jsch 0 1 42 0 1 50 0 1 54 public static void processFiles ArrayList
  • 致命异常:OkHttp 调度程序

    我在 Android 应用程序中使用 OkHttp 库向天气 API 发出 Web 请求 我已经实现了我的代码 但在执行请求时遇到了致命异常 我也已经在我的清单中添加了互联网权限 MainActivity java private Curr
  • 如何使用 iBatis (myBatis) 的注释进行 IN 查询?

    我们只想在 MyBatis 中使用注释 我们确实在努力避免使用 xml 我们尝试使用 IN 子句 Select SELECT FROM blog WHERE id IN ids List
  • 如何将元素添加到通用集合

    我想知道如何将专用对象添加到通用集合中 我正在使用以下代码 Collection

随机推荐

  • 大数据和位置智能:助力企业数字化战略落地

    大数据和位置智能可以在建立用户信任 提高品牌忠诚度 辅助企业运营决策 实现差异化竞争四个方面助力企业数字化落地 麦当劳不是卖汉堡的 它的本质是房地产商 这句话出自约翰 李 汉考执导的麦当劳公司创始人Ray Kroc的传记片 大创业家 作为风
  • sklearn-数据预处理与特征工程

    1 数据预处理 Preprocessing Impute preprocessing MinMaxScaler数据归一化 MinMaxScaler有一个重要参数 feature range 控制我们希望把数据压缩到的范围 默认是 0 1 使
  • javascript利用回调函数解决异步困扰

    虽然已经存在promise StratifiedJS等工具用来解决回调地狱 但是讲真 我觉得他们也并没有让代码的可读性大大增强 而且在回调函数的嵌套次数有限的情况下也不至于成为一个 地狱 所以笔者还是老老实实的继续啃这块js里的板砖 利用回
  • Linux下的MongoDB安装&启动&关闭

    https developer aliyun com article 668662
  • 猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个。到第10天早上时,只剩下一个,求第一天有多少桃子。

    猴子吃桃问题 猴子第一天摘下若干个桃子 当即吃了一半 又多吃了一个第二天早上又将剩下的桃子吃掉一半 又多吃了一个 到第10天早上时 只剩下一个 求第一天有多少桃子 我的思路 用逆向思维推测第一天 由题可知第10天时桃子数量为1 根据规律 第
  • Docker 开启 buildx 多CPU架构镜像制作

    Docker开启buildx多CPU架构镜像制作 buildx简介 关于QEMU 系统限制 查看Linux内核版本 查看Docker版本 Docker开启实验特性 启用 binfmt misc 来运行非本地架构 Docker 镜像 检查 Q
  • Spring MVC+Maven 实现同一项目的前端和后台交互

    在做前端和后台交互时 首先得有一个建立完毕的spring MVC项目 这里我以Maven Spring MVC的HelloWord工程来示例 当然你也可以在你已有的Spring MVC工程下进行操作 建立Spring MVC的HelloWo
  • 【论文随笔】强化学习与奖励机 LTL and Beyond: Formal Languages for Reward Function Specification in RL

    前言 最近对强化学习比较感兴趣 来读一读时序逻辑与强化学习交叉的文章 P S 随着毕业设计的结束 最近恢复了一波旧帖子 另外新建了个人网站 可能慢慢把笔记都移到个人网站上 但就目前而言还是CSDN的编辑器用着更顺手一些些 主要参考文献 Ca
  • python机器学习入门到精通--实战分析(三)

    利用sklearn分析鸢尾花 前面两篇文章提到了机器学习的入门的几个基础库及拓展练习 现在我们就对前面知识点进行汇总进行一个简单的机器学习应用 并构建模型 练习即假定一名植物专家收集了每一朵鸢尾花的测量数据 花瓣的长度和宽度以及花萼的长度和
  • -bash: netstat: 未找到命令

    linux命令报错信息 bash netstat 未找到命令 root localhost netstat anp bash netstat 未找到命令 原因分析 缺少Net tools Net tools 包含一系列程序 是构成了 Lin
  • 本地安装node.js安装,使用npm下载插件

    操作系统 windows10 开发工具 VS Code 1 下载node js文件 全程下一步即可 2 打开vscode 运行终端 此处打开的额终端路径是你当前的项目根目录 node中自带npm 所以安装号node就已经安装号 npm了 使
  • 白鲸开源代立冬:一年5个孵化项目来自于中国,佛系Apache如何帮助中国开源立足全球?

    近两年 在Apache等顶尖开源基金会中涌现出很多像SeaTunnel这样的国产开源项目 但由于起步较晚 中国开源与海外还存在明显差距 那么中国开源该如何追赶 本期 开源访谈录 邀请到了Apache mentor代立冬来分享他的见解 本期受
  • Ubuntu 20.04vscode配置C语言

    网上好多都是乱七八糟的 调的我心烦 我自己把自己配置成功的拿出来方在这里给大家看了 vscode配置C语言实际上就是每个文件夹修改一下launch json和tasks json文件 launch json version 0 2 0 co
  • Google分布式三篇论文--MapReduce

    MapReduce 超大机群上的简单数据处理 摘要 MapReduce是一个编程模型 和处理 产生大数据集的相关实现 用户指定一个map函数处理一个key value对 从而产生中间的key value对集 然后再指定一个reduce函数合
  • SpringBoot2.0之整合Apollo

    SpringBoot2 0之整合Apollo Spring Boot客户端对接阿波罗服务器端 核心源码都在这个压缩包里面 封装好了环境 运行shell脚本就ok了 下面进入到本地maven仓库 远程仓库apollo的jar包 只能打包到本地
  • 【路径规划】基于模糊逻辑系统实现车辆的自主导航附matlab代码

    1 内容介绍 在过去的30年 用于城市地面交通工具中自动驾驶技术的开发已经得到了飞速的发展 目前 现代自主驾驶车辆已具备一定感知车辆周围环境的能力 比如根椐分类所分析对象的类型并进行检测 观测周身环境的变化并评估对象的移动可能性 在遵循交通
  • 交换瓶子

    交换瓶子 贡献者 programmer ada 有N个瓶子 编号 1 N 放在架子上 比如有5个瓶子 2 1 3 5 4 要求每次拿起2个瓶子 交换它们的位置 经过若干次后 使得瓶子的序号为 1 2 3 4 5 对于这么简单的情况 显然 至
  • SpringBoot Controller 提取Post请求中Body的参数问题——驼峰命名规则

    正常在Controller方法中使用 RequestBody 类 对象进行参数接收 通过ApiFox对对应接口发起请求 但控制台打印内容为空 原因 ApiFox中设置json格式的body参数时 变量名未遵循驼峰命名规则 类似于printE
  • Qt样式表的使用

    Qt中可以灵活的使用层叠样式表 CSS 其语法和CSS很相似 因为HTML CSS的灵活性 所以可以很方便的为QT界面设计自己需要的外观 除了子类化Style类 使用QT样式表 QStyleSheet 是另一种快速改变QT程序UI风格的方法
  • java开发记录-微信二维码支付

    关于微信二维码支付的一点点总结 如上一个博客所说 开始开发前需要前往官网进行一系列的接入 从而得到相关的appid 密钥 本次的开发中 使用谷歌zxing实现将支付链接字符串转为二维码 附上相关依赖