## 用ThinkPHP6寫一個,可以隨機生成20萬中文昵稱、時間戳、IP地址、姓名、身份證號碼、手機號的程序,并且可以寫入數據庫
創建一個控制器
```
<?php
namespace app\index\controller;
use think\Controller;
use think\Db;
class RandomController extends Controller
{
public function index()
{
// 生成20萬個隨機數據
$data = [];
for($i = 0; $i < 200000; $i++){
$data[] = [
'nickname' => $this->generateNickname(),
'timestamp' => $this->generateTimestamp(),
'ip_address' => $this->generateIpAddress(),
'name' => $this->generateName(),
'id_number' => $this->generateIdNumber(),
'phone_number' => $this->generatePhoneNumber(),
];
}
// 寫入數據庫
Db::name('random_data')->insertAll($data);
return '生成成功';
}
private function generateNickname()
{
// 生成一個3-10個漢字的昵稱
$length = mt_rand(3, 10);
$name = '';
for ($i = 0; $i < $length; $i++) {
$name .= mb_chr(mt_rand(0x4E00, 0x9FA5));
}
return $name;
}
private function generateTimestamp()
{
// 生成一個隨機的時間戳
$timestamp = mt_rand(0, time());
return date('Y-m-d H:i:s', $timestamp);
}
private function generateIpAddress()
{
// 生成一個隨機的IPv4地址
$ip = [];
for($i = 0; $i < 4; $i++) {
$ip[] = mt_rand(0, 255);
}
return implode('.', $ip);
}
private function generateName()
{
// 生成一個隨機的中文姓名
$surname = [
'趙', '錢', '孫', '李', '周', '吳', '鄭', '王', '馮', '陳',
'楮', '衛', '蔣', '沈', '韓', '楊', '朱', '秦', '尤', '許',
'何', '呂', '施', '張', '孔', '曹', '嚴', '華', '金', '魏',
'陶', '姜', '戚', '謝', '鄒', '喻', '柏', '水', '竇', '章',
'云', '蘇', '潘', '葛', '奚', '范', '彭', '郎', '魯', '韋',
'昌', '馬', '苗', '鐘', '駱', '戴', '賈', '田', '堵', '儲',
'盧', '杜', '胡', '南宮', '歐陽', '夏侯', '諸葛', '皇甫',
'司馬', '公孫', '慕容', '長孫', '司徒', '軒轅', '令狐',
'宇文', '司空', '鮮于', '閭丘', '東方', '子車', '呼延',
'赫連', '司寇', '浦', '尚', '農', '溫', '別', '莊', '晏',
'柴', '瞿', '閻', '充', '慕', '連', '茹', '習', '宦',
'艾', '魚', '容', '向', '古', '易', '慎', '戈', '廖',
'庾', '終', '暨', '居', '衡', '步', '都', '耿', '滿',
'弘', '匡', '文', '國', '寇', '廣', '祿', '闕', '東',
'歐', '殳', '沃', '利', '蔚', '越', '夔', '隆', '師',
'鞏', '厙', '聶', '晁', '勾', '敖', '融', '冷', '訾',
'辛', '闞', '那', '簡', '饒', '空', '曾', '毋', '沙',
'乜', '養', '鞠', '須', '豐', '巢', '關', '蒯', '相',
'查', '后', '荊', '紅', '游', '竺', '權', '逯', '蓋',
'益', '桓', '公', '萬', '俟', '司空'];
$name = $surname[mt_rand(0, count($surname) - 1)];
$length = mt_rand(1, 2);
for($i = 0; $i < $length; $i++) {
$name .= mb_chr(mt_rand(0x4E00, 0x9FA5));
}
return $name;
}
private function generateIdNumber()
{
// 生成一個隨機的身份證號碼
$region = ['1101', '1201', '1301', '1401', '1501'];
$year = mt_rand(1970, 2000);
$month = str_pad(mt_rand(1, 12), 2, '0', STR_PAD_LEFT);
$day = str_pad(mt_rand(1, 28), 2, '0', STR_PAD_LEFT); $suffix = str_pad(mt_rand(1, 9999), 4, '0', STR_PAD_LEFT); $id_number = $region[mt_rand(0, count($region) - 1)] . $year . $month . $day . $suffix; return $id_number;
}
private function generatePhoneNumber()
{
// 生成一個隨機的手機號碼
$prefix = ['130', '131', '132', '133', '134', '135', '136', '137', '138', '139', '150', '151', '152', '153', '154', '155', '156', '157', '158', '159', '170', '176', '177', '178', '180', '181', '182', '183', '184', '185', '186', '187', '188', '189'];
$number = $prefix[mt_rand(0, count($prefix) - 1)] . str_pad(mt_rand(0, 99999999), 8, '0', STR_PAD_LEFT);
return $number;
}
}
```
在數據庫中創建一個名為random\_data的表:
```
CREATE TABLE `random_data` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',
`nickname` varchar(20) NOT NULL DEFAULT '' COMMENT '昵稱',
`timestamp` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '時間戳',
`ip_address` varchar(15) NOT NULL DEFAULT '' COMMENT 'IP地址',
`name` varchar(10) NOT NULL DEFAULT '' COMMENT '姓名',
`id_number` varchar(18) NOT NULL DEFAULT '' COMMENT '身份證號碼',
`phone_number` varchar(11) NOT NULL DEFAULT '' COMMENT '手機號碼', PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='隨機數據表';
```
- Golang
- Beego框架
- Gin框架
- gin框架介紹
- 使用Gin web框架的知名開源線上項目
- go-admin-gin
- air 熱啟動
- 完整的form表單參數驗證語法
- Go 語言入門練手項目推薦
- Golang是基于多線程模型
- golang 一些概念
- Golang程序開發注意事項
- fatal error: all goroutines are asleep - deadlock
- defer
- Golang 的內建調試器
- go部署
- golang指針重要性
- 包(golang)
- Golang框架選型比較: goframe, beego, iris和gin
- GoFrame
- golang-admin-項目
- go module的使用方法及原理
- go-admin支持多框架的后臺系統(go-admin.cn)
- docker gocv
- go-fac
- MSYS2
- 企業開發框架系統推薦
- gorm
- go-zero
- 優秀系統
- GinSkeleton(gin web 及gin 知識)
- 一次 request -> response 的生命周期概述
- 路由與路由組以及gin源碼學習
- 中間件以及gin源碼學習
- golang項目部署
- 獨立部署golang
- 代理部署golang
- 容器部署golang
- golang交叉編譯
- goravel
- kardianos+gin 項目作為windows服務運行
- go env
- 適用在Windows、Linux和macOS環境下打包Go應用程序的詳細步驟和命令
- Redis
- Dochub
- Docker部署開發go環境
- Docker部署運行go環境
- dochub說明
- Vue
- i18n
- vue3
- vue3基本知識
- element-plus 表格單選
- vue3后臺模板
- Thinkphp
- Casbin權限控制中間件
- 容器、依賴注入、門面、事件、中間件
- tp6問答
- 偽靜態
- thinkphp-queue
- think-throttle
- thinkphp隊列queue的一些使用說明,queue:work和queue:listen的區別
- ThinkPHP6之模型事件的觸發條件
- thinkphp-swoole
- save、update、insert 的區別
- Socket
- workerman
- 介紹
- 從ThinkPHP6移植到Webman的一些技術和經驗(干貨)
- swoole
- swoole介紹
- hyperf
- hf官網
- Swoft
- swoft官網
- easyswoole
- easyswoole官網地址
- EASYSWOOLE 聊天室DEMO
- socket問答
- MySQL
- 聚簇索引與非聚簇索引
- Mysql使用max獲取最大值細節
- 主從復制
- 隨機生成20萬User表的數據
- MySQL進階-----前綴索引、單例與聯合索引
- PHP
- 面向切面編程AOP
- php是單線程的一定程度上也可以看成是“多線程”
- PHP 線程,進程、并發、并行 的理解
- excel數據畫表格圖片
- php第三方包
- monolog/monolog
- league/glide
- 博客-知識網站
- php 常用bc函數
- PHP知識點的應用場景
- AOP(面向切面編程)
- 注解
- 依賴注入
- 事件機制
- phpspreadsheet導出數據和圖片到excel
- Hyperf
- mineAdmin
- 微服務
- nacos注冊服務
- simps-mqtt連接客戶端simps
- Linux
- 切換php版本
- Vim
- Laravel
- RabbitMQ
- thinkphp+rabbitmq
- 博客
- Webman框架
- 框架注意問題
- 關于內存泄漏
- 移動端自動化
- 懶人精靈
- 工具應用
- render
- gitlab Sourcetree
- ssh-agent失敗 錯誤代碼-1
- 資源網站
- Git
- wkhtmltopdf
- MSYS2 介紹
- powershell curl 使用教程
- NSSM(windows服務工具)
- MinGW64
- 知識擴展
- 對象存儲系統
- minio
- 雪花ID
- 請求body參數類型
- GraphQL
- js 深拷貝
- window 共享 centos文件夾
- 前端get/post 請求 特殊符號 “+”傳參數問題
- 什么是SCM系統?SCM系統與ERP系統有什么區別?
- nginx 日志格式統一為 json
- 特殊符號怎么打
- 收藏網址
- 收藏-golang
- 收藏-vue3
- 收藏-php
- 收藏-node
- 收藏-前端
- 規劃ITEM
- 旅游類
- 人臉識別
- dlib
- Docker&&部署
- Docker-compose
- Docker的網絡模式
- rancher
- DHorse
- Elasticsearch
- es與kibana都docke連接
- 4種數據同步到Elasticsearch方案
- GPT
- 推薦系統
- fastposter海報生成
- elasticsearch+logstash+kibana
- beego文檔系統-MinDoc
- jeecg開源平臺
- Java
- 打包部署
- spring boot
- 依賴
- Maven 相關 命令
- Gradle 相關命令
- mybatis
- mybatis.plus
- spring boot 模板引擎
- SpringBoot+Maven多模塊項目(創建、依賴、打包可執行jar包部署測試)完整流程
- Spring Cloud
- Sentinel
- nacos
- Apollo
- java推薦項目
- gradle
- Maven
- Nexus倉庫管理器
- Python
- Masonite框架
- scrapy
- Python2的pip2
- Python3 安裝 pip3
- 安全攻防
- 運維技術
- 騰訊云安全加固建議
- 免費freessl證書申請
- ruby
- homeland
- Protobuf
- GIT
- FFMPEG
- 命令說明
- 音頻
- ffmpeg合并多個MP4視頻
- NODEJS
- 開發npm包
- MongoDB
- php-docker-mongodb環境搭建
- mongo基本命令
- Docker安裝MongoDB最新版并連接
- 少兒編程官網
- UI推薦
- MQTT
- PHP連接mqtt
- EMQX服務端
- php搭建mqtt服務端