微信openid存入数据库为空解决方案

在处理微信openid存入数据库时,发现openid变为空。问题出在使用header进行页面跳转获取code时,代码并未停止执行。由于没有在header跳转后立即终止程序,导致在code未获取到的情况下尝试保存openid,从而存入了空值。通过在Header跳转语句后添加die,成功解决了问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

首先openid是字符串,大家应该都考虑到了。我这的问题是打印openid,输出sql正常,打印sql和执行语句和吧sql存文件时openid就变成了空?原因是第一步获取code时使用header跳转时代码接着往下执行了!

分析如下 :进入首页(msp.php)判断用户有没有存opeid 没有的话进入这个页面存openid(openid.php代码如下),本页第一步获取code使用Header跳转页面并没有die终止导致程序继续往下运行,我觉得跳转页面了不应该运行下面的代码了。 往下继续运行时并没有code获取到openid也不存在所以数据库存的是空,而Header跳转到本页面了,应该正确流程再添加一条正确的记录的 但是只有1条open为空记录 这什么情况!不过Header("Location: $shouquan");die;加个die问题解决了  耗时2H。

if(!$_REQUEST['code']){
    $shouquan = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=$appid&redirect_uri=https://www.jifen.com/mobile/openid.php&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect";
    Header("Location: $shouquan");die;
}
$code=$_REQUEST['code']; //接收code
$open_url="https://api.weixin.qq.com/sns/oauth2/access_token?appid=$appid&se
以下是一个示例代码模块,用于将获取的用户openid存入数据库中: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; public class WechatOpenIdDao { private static final String DB_URL = "jdbc:mysql://localhost:3306/mydatabase"; private static final String DB_USERNAME = "username"; private static final String DB_PASSWORD = "password"; public void saveOpenId(String openid) { Connection conn = null; PreparedStatement stmt = null; try { // 连接数据库 conn = DriverManager.getConnection(DB_URL, DB_USERNAME, DB_PASSWORD); // 定义SQL语句 String sql = "INSERT INTO wechat_users (openid) VALUES (?)"; // 创建PreparedStatement对象 stmt = conn.prepareStatement(sql); // 设置参数 stmt.setString(1, openid); // 执行更新操作 stmt.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } finally { // 关闭资源 try { if (stmt != null) { stmt.close(); } if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); } } } } ``` 在上述示例代码中,我们使用了Java的JDBC API来连接数据库,并执行SQL语句。我们定义了一个`saveOpenId`方法,用于将获取到的用户openid存入名为`wechat_users`的数据库表中。在方法中,我们首先定义了数据库的URL、用户名和密码,然后连接数据库,并执行SQL语句。我们使用了`PreparedStatement`对象来创建SQL语句,并设置参数。最后,我们通过调用`executeUpdate`方法来执行SQL语句。 请注意,上述代码仅仅是一个示例,实际上,您需要在代码中添加更多的异常处理和安全性检查。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值