小菜鸟web项目接入支付宝沙箱环境所遇到的坑

具体配置支付宝沙箱,参考下面文章链接:

https://blog.csdn.net/qq_27690839/article/details/79609717

1.问题1

// 服务器异步通知页面路径  需http://格式的完整路径,不能加?id=123这类自定义参数,必须外网可以正常访问
	public static String notify_url = "http://域名/notify_url.jsp";

	// 页面跳转同步通知页面路径 需http://格式的完整路径,不能加?id=123这类自定义参数,必须外网可以正常访问
	public static String return_url = "http://ip地址:80/return_url.jsp";

 同步跳转的页面地址,其实用内网ip地址也一样可以访问,不需要外网。如果没有外网域名,可以去natapp官网上申请一个免费通道。但是需要实名注册一下。异步和同步,支付成功后是先异步访问异步的地址,再访问同步的地址

2.问题2

demo上说运行index页面,其实是要自己配置Tomcat,我配置的web如下,可以把原demo的web..什么的改名为web

3.问题3

	//请求
	String result = alipayClient.pageExecute(alipayRequest).getBody();
	
	//输出
	out.println(result);

 如果我们是在后台写这段代码,result其实是一段html代码,需要返回到前台,放到前台页面上,这段代码就会自动提交申请,去到支付宝支付页面。

4.问题4

支付宝支付成功后异步和同步返回,不管session设置了多久过期,反正session都会过期。在网上搜的解决办法,大致是先用redis数据库把session 信息保存下来,等回调的时候再把redis数据库的信息取出来放到session中去。但是redis的配置又是坑多多。

5.问题5

 redia配置

可以先写一个redis连接的工具类

 

public class RedisUtil {


    //服务器IP地址
    private static String ADDR = "127.0.0.1";
    //端口
    private static int PORT = 6379;
    //密码
    private static String AUTH = "你的密码";
    //连接实例的最大连接数
    private static int MAX_ACTIVE = 1024;
    //控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。
    private static int MAX_IDLE = 200;
    //等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException
    private static int MAX_WAIT = 10000;
    //连接超时的时间  
    private static int TIMEOUT = 10000;
    // 在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;
    private static boolean TEST_ON_BORROW = true;

    private static JedisPool jedisPool = null;
    //数据库模式是16个数据库 0~15
    public static final int DEFAULT_DATABASE = 0;
    /**
     * 初始化Redis连接池
     */

    static {

        try {

            JedisPoolConfig config = new JedisPoolConfig();
            config.setMaxTotal(MAX_ACTIVE);
            config.setMaxIdle(MAX_IDLE);
            config.setMaxWaitMillis(MAX_WAIT);
            config.setTestOnBorrow(TEST_ON_BORROW);
            jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT,AUTH,DEFAULT_DATABASE);

        } catch (Exception e) {

            e.printStackTrace();
        }

    }

    /**
     * 获取Jedis实例
     */

    public synchronized static Jedis getJedis() {

        try {

            if (jedisPool != null) {
                Jedis resource = jedisPool.getResource();
                System.out.println("redis--服务正在运行: "+resource.ping());
                return resource;
            } else {
                return null;
            }

        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }

    }

    /***
     *
     * 释放资源
     */

    public static void returnResource(final Jedis jedis) {
        if(jedis != null) {
            jedisPool.returnResource(jedis);
        }

    }
}

 

 之后导包一直有问题,咋导都不行,网上还看到说,commons-pool2包官网最新的jar包有问题,要自己下载源码编译。最后查找众多文章,终于找到了最佳的导包方法。

   <dependency>
      <groupId>org.apache.commons</groupId>
      <artifactId>commons-pool2</artifactId>
      <version>2.5.0</version>
    </dependency>

    <!-- https://mvnrepository.com/artifact/commons-pool/commons-pool -->
    <dependency>
      <groupId>commons-pool</groupId>
      <artifactId>commons-pool</artifactId>
      <version>1.5.4</version>
    </dependency>

    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-data-redis</artifactId>
      <exclusions>
        <exclusion>
          <groupId>io.lettuce</groupId>
          <artifactId>lettuce-core</artifactId>
        </exclusion>
      </exclusions>
    </dependency>
    <dependency>
      <groupId>redis.clients</groupId>
      <artifactId>jedis</artifactId>
      <version>2.7.1</version><!--版本号可根据实际情况填写-->
    </dependency>
posted @ 2019-10-18 11:41  飞刀寻欢  阅读(858)  评论(0编辑  收藏  举报
……