当前位置: 首页 > wzjs >正文

做冠县梨园网站怎么做微信优惠群怎么做网站

做冠县梨园网站怎么做,微信优惠群怎么做网站,互联网推广怎么学,seo知识分享操作数据库的时候经常会遇到报错:SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry ,报错信息给开发者调试没问题,直接展示给用户的话,用户就以为是程序乱码或者程序有问题,实际上是原始提示太…

操作数据库的时候经常会遇到报错:SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry ,报错信息给开发者调试没问题,直接展示给用户的话,用户就以为是程序乱码或者程序有问题,实际上是原始提示太不直观 

你可以通过自定义异常类来提供更友好的提示信息。以下是实现方案:

1. 创建自定义数据库异常类

<?php
namespace app\exception;use think\Exception;class DatabaseOperationException extends Exception
{// 常见数据库错误码映射const ERROR_MAP = [1062 => '数据已存在,请勿重复添加',1451 => '操作失败,存在关联数据',1452 => '操作失败,关联数据不存在',// 可以添加更多错误码映射];// 字段重复映射(可根据需要扩展)const FIELD_MAP = ['id_code' => '身份证号','username' => '用户名','email' => '邮箱','phone' => '手机号',];public function __construct($message = "", $code = 0, \Throwable $previous = null){// 如果是已知的数据库错误码,转换为友好提示if (preg_match('/SQLSTATE\[23000\]:.*1062.*Duplicate entry \'.*\' for key \'(\w+)\'/', $message, $matches)) {$field = $matches[1] ?? '';$fieldName = self::FIELD_MAP[$field] ?? $field;$message = "{$fieldName}已存在,请勿重复添加";$code = 1062;}parent::__construct($message, $code, $previous);}/*** 从数据库异常创建自定义异常*/public static function createFromDbException(\Throwable $e){// 尝试从错误信息中提取错误码if (preg_match('/SQLSTATE\[23000\]:.*(\d{4})/', $e->getMessage(), $matches)) {$errorCode = $matches[1] ?? 0;$message = self::ERROR_MAP[$errorCode] ?? $e->getMessage();return new self($message, $errorCode, $e);}return new self($e->getMessage(), $e->getCode(), $e);}
}

2. 使用方式

try {// 尝试创建用户$user = User::create($userData);
} catch (\think\db\exception\DbException $e) {// 转换为自定义异常throw DatabaseOperationException::createFromDbException($e);
} catch (\Exception $e) {// 其他异常处理throw new \Exception('操作失败,请稍后再试');
}

 3. 全局异常处理(可选)

// 在app/ExceptionHandle.php中public function render($request, \Throwable $e): Response
{// 如果是数据库操作异常if ($e instanceof \think\db\exception\DbException) {$friendlyException = DatabaseOperationException::createFromDbException($e);return json(['code' => 400,'msg' => $friendlyException->getMessage(),'data' => null]);}// 其他异常处理...return parent::render($request, $e);
}

 

4. 效果

当用户尝试添加重复的身份证号时,原本的:

SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry '220********25' for key 'id_code'

将被转换为更友好的提示: 

身份证号已存在,请勿重复添加 

5. 扩展建议

  1. 可以根据业务需要扩展FIELD_MAPERROR_MAP,添加更多字段和错误码的映射

  2. 对于多语言应用,可以将提示信息改为从语言包读取

  3. 可以记录原始异常信息到日志,便于调试

这种方式既保持了原始错误信息的完整性(通过日志),又为用户提供了友好的界面提示。

 

http://www.dtcms.com/wzjs/787621.html

相关文章:

  • 网站备案账号是什么价格低怎么说好听
  • 梅州哪里做网站免费个人网站怎么制作
  • 做足球采集软件和预测软件的网站网站 二级域名需要备案吗
  • 北京php网站制作网络整合营销是什么意思
  • 做公司企业网站昆明做网站建设有哪些
  • 网站图片尺寸保定哪家做网站好
  • 惠州微网站推广方案做网站用什么服务器比较好
  • 摄影网站免费源码沈阳发布最新通告
  • 建站教程中建招聘官网入口
  • 做旅游网站的网站如何做市场推广
  • 怎么做自己的网站宁波专业建网站外包
  • 泰州网站建设外包wordpress4.6+中文
  • 国内网站制作欣赏网站安全防护方案
  • 网页设计网站怎么做wordpress 报名
  • 模板网站的劣势内容企业推广
  • 花店网站模板 html视觉设计师的工作内容
  • 建设银行如何进行网站冻结做视频网站视频文件都存放在哪里
  • 网站制作语言有哪些wordpress图片模糊加载
  • 公司做网站之前要准备什么软件wordpress关联博客
  • 浏览有关小城镇建设的网站 记录网站建设288
  • 免费看电视剧的网站在线观看济南wordpress 建站
  • 自学网站有哪些自学网餐饮品牌策划设计公司
  • 微信网站制作免费企业公司做网站
  • 网站搭建平台有哪些甘肃网络推广公司
  • 黑龙江省建设网官方网站wordpress不能发送邮件
  • 在线花钱做网站iis 网站启动不了
  • 微信做购物网站怎么抽佣做房产信息互联网网站需要什么资质
  • jsp环保主题网站代做免费咨询会计
  • 怎么做网站源代码办宽带需要多少钱一月
  • 空壳网站wordpress背景高斯模糊