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

一起做网店网站官方seo推广方法

一起做网店网站官方,seo推广方法,2018武汉做网站的价格,rp怎么做网站操作数据库的时候经常会遇到报错: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/173138.html

相关文章:

  • 郑州网站建设的公司哪家好云南疫情最新数据消息中高风险地区
  • 西安市做网站的公司百度收录技术
  • 网站的工作简报怎么做怎么给网站做优化
  • 建设一家网站多少钱专业营销策划团队
  • 淘客网站如何做滕州百度推广
  • 送菜上门网站app如何做个人网站免费制作平台
  • wordpress文章关联微信廊坊seo培训
  • wap网站 手机网站百度网络营销中心客服电话
  • 企业自己如何做网站推广开发一个网站
  • 如何制作企业内部网站珠海百度seo
  • 黄石市城乡建设网站网上推广培训
  • 网站头部优化文字怎么做网站如何让百度收录
  • 高端建站什么意思sem是什么检测分析
  • 做壁纸网站好东莞网站优化公司
  • 网站建设中什么意思广州网站推广服务
  • 开发中英文切换网站如何做青岛seo优化
  • 网站建设和网站运营包括什么站长工具是什么意思
  • 给个2021站你们懂得不花钱的宁波seo推广费用
  • 个人做网站开发seo模拟点击有用吗
  • 网站风格设定中国营销网官网
  • 怎样办网站杭州seo优化
  • 3d模型代做网站网站制作河南
  • 旅游包车网站最新模板长沙网站seo推广公司
  • 在线做爰视频网站百度怎么推广产品
  • 企业为什么要并购昆明百度搜索排名优化
  • 正规网站建设建设公司百度推广登陆网址
  • 网站备案一般由谁来做四川seo快速排名
  • 永久短网址生成seo综合查询什么意思
  • 网站SEO容易做吗线上产品推广方案
  • 电商网站设计页面设计深圳网站关键词排名优化