go-zero微服务框架 api 案例
最外层可以引入://=====================================> blog api v1 <================================= import ( "api/role.api" "api/menu.api" "api/user.api" "api/upload.api" "api/member.api" "api/article.api" )user.apiinfo( author: "lxl" date: "2022-12-20" desc: "user-api" email: "1123736022@qq.com" version: "v1" ) type ( // 一个用户 UserList { Id int64 `json:"id"` //ID UserName string `json:"userName"` //用户名 Password string `json:"password"` //密码 NickName string `json:"nickName"` //昵称 Email string `json:"email"` //邮箱 Image string `json:"image"` //头像 CreateTime int64 `json:"createTime"` UpdateTime int64 `json:"updateTime"` } // 用户列表请求 UserListReq { Page int64 `json:"page"` PageSize int64 `json:"pageSize"` NickName string `json:"nickName"` Email string `json:"email"` } // 用户列表响应 UserListResp { List []UserList `json:"list"` Code int64 `json:"code"` Msg string `json:"msg"` Total int64 `json:"total"` } // 用户新增请求 AddUserReq { UserName string `json:"userName"` //用户名 Password string `json:"password"` //密码 NickName string `json:"nickName"` //昵称 Email string `json:"email"` //邮箱 Image string `json:"image"` //头像 } // 删除用户请求 delUserReq { Id int64 `json:"id"` } // 批量删除用户请求 batchDelUserReq { Ids string `json:"ids"` } // 获取用户信息响应 UserInfoReply { // UserInfo UserList `json:"user_info"` Id string `json:"id"` Name string `json:"name"` } // 用户登录请求 UserLoginReq { UserName string `json:"userName"` //用户名 Password string `json:"password"` //密码 } // 用户登录响应 UserLoginResp { Code int64 `json:"code"` Msg string `json:"msg"` } // 用户响应 UserResp { Code int64 `json:"code"` Msg string `json:"msg"` Token string `json:"token"` UserInfo GetUserResponse `json:"userInfo"` } // 获取用户信息请求 GetUserRequest { Id int64 `json:"id"` } GetUserResponse { Id int64 `json:"id"` //ID UserName string `json:"userName"` //用户名 NickName string `json:"nickName"` //昵称 Email string `json:"email"` //邮箱 Image string `json:"image"` //头像 CreateTime int64 `json:"createTime"` UpdateTime int64 `json:"updateTime"` } JwtTokenRequest { } JwtTokenResponse { AccessToken string `json:"access_token"` AccessExpire int64 `json:"access_expire"` RefreshAfter int64 `json:"refresh_after"` // 建议客户端刷新token的绝对时间 } ) @server( prefix: api group: user jwt: JwtAuth ) service blog { // 获取用户列表 @handler getUserList post /user/getUserList (UserListReq) returns (UserListResp) // 添加用户 @handler addUser post /user/addUser (AddUserReq) returns (UserResp) // 更新用户 @handler updateUser post /user/updateUser (UserList) returns (UserResp) // 删除用户用户 @handler delUser post /user/delUser (delUserReq) returns (UserResp) // 批量删除用户用户 @handler batchDelUser post /user/batchDelUser (batchDelUserReq) returns (UserResp) // 获取用户信息 @handler getUserInfo post /user/info (GetUserRequest) returns (GetUserResponse) } @server( prefix: api group: user ) service blog { @handler userLogin post /user/login (UserLoginReq) returns (UserLoginResp) @handler JwtHandler post /user/token (JwtTokenRequest) returns (JwtTokenResponse) }
查看详情点赞评论收藏浏览222023-02-27 18:57:46linux 常用命令
nmcli dev status 查看设备状态包括我网卡nmcli con up ens33 查看网卡 cd /etc/sysconfig/network-scripts/ 切换网络配置(这里是网络配置文件)systemctl start network 或service network restart #重启网络服务没有ifconfig命令需要安装,执行yum install net-tools -yTYPE=Ethernet PROXY_METHOD=none BROWSER_ONLY=no BOOTPROTO=dhcp DEFROUTE=yes IPV4_FAILURE_FATAL=no IPV6INIT=yes IPV6_AUTOCONF=yes IPV6_DEFROUTE=yes IPV6_FAILURE_FATAL=no IPV6_ADDR_GEN_MODE=stable-privacy NAME=enp0s10 UUID=066c9671-2047-483a-8bf8-6660299e3eae DEVICE=enp0s10 ONBOOT=yes IPADDR=192.168.56.102 GATWAY=172.16.0.1 DNS1=61.139.2.69yum 安装阿里云镜像软件,下载好软件,并配置好环境vi i esc :wq 打开文件,编辑,退出编辑,保存退出yum install vim 可以安装vim yum remove vim 不要可以yum卸载 grep: 查找 第一个命令可以享用到第二个命令中ps:可以查询出我们系统运行的进程,可以与grep 配合使用ps -aux | grep .... kill -9 pid 杀死一个进程 -9是强制杀死 kill pidchown 更改目录的用户及用户组 chmod 修改文件的权限,推荐直接一点777 chown -R root:root xxx/ chmod -R 755 xxx有一个需求。每天4点定时备份数据库:1、备份数据库的方方式:# mysqldump -u root -p test > /www/test.sqlmysqldump -uroot -p123456 test > /www/test.sql可以把用户或密码写一起,只是会发出一个警告-uroot -p123456shell脚本:echo 是输出,同事也可以帮助liunx运行需要的命令vi mysql_dump.shchmod +x ./mysql_dump.sh./mysql_dump.sh #运行这个文件,这个文件里写了上面的命令就会执行然后定时:会用到定时器。linux定时器只能精确到分钟 crontab -e #编辑定时器* * * * * 第一个星:每分钟0-59,2个:每小时0-23,第三个是小时及天* * * * * 每隔一分支用cat /etc/crontab #查看这个下面的定时器crontab -e1 * * * * /www/mysql_dump.sh查找文件:有时候忘记文件在那里可以查询:find / -name mysql_dump.sh 或者 find / -name mysql_dump*打包文件:打包成什么文件格式 被打包文件夹tar -czvf myetc.tar.gz etc解压:tar -zxvf 文件 卸载:yum remove libziplinux安装pip:下载文件 wget https://bootstrap.pypa.io/get-pip.py --no-check-certificate 执行安装 python get-pip.py复制:cp 111.txt ./111bak.txt上传下载:安装 yum install -y lrzsz sz:下载保存 rz:上传文件删除文件:rm -f 强制删除:rm -rf查看端口:netstat -anp | grep 端口 netstat -nultp //不加端口,列出被占服务端口1:查看防火状态systemctl status firewalld service iptables status2:暂时关闭防火墙systemctl stop firewalld service iptables stop或者:#查看防火墙状态 systemctl status firewalld # 开启 sudo service firewalld start # 重启 sudo service firewalld restart # 关闭 sudo service firewalld stop查看监听端口:netstat -anp | grep 9501 然后杀死: kill pid kill -9 pid //强制杀死PHP 停止重启pkill php-fpm //停止 /www/server/php/74/sbin/php-fpm //启动PHP service php-fpm restart //重启MySQL 停止重启service mysqld status //查看MySQL启动状态 service mysqld stop 或者 /etc/init.d/mysqld stop //停止MySQL service mysqld start 或者 /etc/init.d/mysqld start //启动MySQL service mysqld restart 或者 /etc/init.d/mysqld restart //重启MySQLNginx 停止重启ps -ef | grep nginx //查看是否启动 /www/server/nginx/sbin/nginx -s reload //重启nginx /www/server/nginx/sbin/nginx 或者 /etc/init.d/nginx start //启动nginx /etc/init.d/nginx stop //停止nginx /etc/init.d/nginx restart //重启nginx显示行数::set nugrep '查找内容' 文件名//nginx url转发 反向代理,TP,laravel等加速location /{proxy_pass http://192.168.56.102:9000;}wdcp:nginx/www/wdlinux/nginx/sbin/nginx 这个是启动/www/wdlinux/nginx/sbin/nginx -s reload 这个是重启/www/wdlinux/nginx/sbin/nginx -t 这个是检测配置文件,如果写的不对的话会报错的,对正在运行的nginx不会影响which 命令在Linux中可以查询我们的终端命令保存在哪里which python //查询 /usr/bin/python ls -lh /usr/bin/python //查看Python这个文件大小,只是一个软连接 ls -lh /usr/bin/python2.7 //查看具体文件大小查看服务器开放了哪些端口:firewall-cmd --list-all
查看详情点赞评论收藏浏览412023-02-27 19:11:46linux 安装node环境
linux 安装前端环境:安装node1、去官网下载和自己系统匹配的文件: 英文网址:https://nodejs.org/en/download/ 中文网址:http://nodejs.cn/download/ 通过 uname -a 命令查看到我的Linux系统位数是64位(备注:x86_64表示64位系统, i686 i386表示32位系统)2、上传进去服务器1)上传服务器可以是自己任意路径,目前我的放置路径为 cd /app/software/2)解压上传(解压后的文件我这边将名字改为了nodejs,这个地方自己随意,只要在建立软连接的时候写正确就可以) ① tar -xvf node-v6.10.0-linux-x64.tar.xz ② mv node-v6.10.0-linux-x64 nodejs ③确认一下nodejs下bin目录是否有node 和npm文件,如果有执行软连接,如果没有重新下载执行上边步骤;cd /etcvi profile 最后加两行export NODEJS_HOME=/www/server/nodejs/node-v14.15.1-linux-x64export PATH=$PATH:$NODEJS_HOME/bin立即生效source /etc/profile[root@localhost ~]# node -v v12.18.1上面可以就不用下面3)建立软连接,变为全局 ①ln -s /app/software/nodejs/bin/npm /usr/local/bin/ ②ln -s /app/software/nodejs/bin/node /usr/local/bin/4)最后一步检验nodejs是否已变为全局 在Linux命令行node -v 命令会显示nodejs版本,如图所示为大功告成安装yarnnpm install -g yarn安装VUE CLI3 脚手架npm install -g @vue/clivue --versionvue ui 或者 npm run serve//设置淘宝源npm config set registry https://registry.npm.taobao.org//设置公司的源(dgg)npm config set registry https://xxx.xxx.cn///查看源,可以看到设置过的所有的源npm config get registry资源线前端启动(服务不会停):/www/wwwroot/ziyuanxian.shupian.com.cn/webnohup npm run serve > ./nodezyx.log 2>&1 &切换用户:su rootsu www
查看详情点赞评论收藏浏览552023-02-27 19:31:15laravel+layui后台文件上传到本地
上传图片PHP控制器//文件上传 public function upload(Request $request) { //上传文件最大大小,单位M $maxSize = 1; //支持的上传图片类型 $allowed_extensions = ["png", "jpg", "gif"]; //返回信息json $data = ['code'=>1, 'msg'=>'上传失败', 'data'=>'']; $file = $request->file('file'); $filename = $request->all('filename')['filename']; //检查文件是否上传完成 if ($file->isValid()){ //检测图片类型 $ext = $file->getClientOriginalExtension(); if (!in_array(strtolower($ext),$allowed_extensions)){ $data['msg'] = "请上传".implode(",",$allowed_extensions)."格式的图片"; return response()->json($data); } //检测图片大小 if ($file->getSize() > $maxSize*1024*1024){ $data['msg'] = "图片大小限制".$maxSize."M"; return response()->json($data); } }else{ $data['msg'] = $file->getErrorMessage(); return response()->json($data); } $year = date('Y'); $date = date('m-d'); $newFile = md5(uniqid()).".".$file->getClientOriginalExtension(); $disk = Storage::disk('uploads'); $res = $disk->put('/'.$filename.'/'.$year.'/'.$date.'/'.$newFile,file_get_contents($file->getRealPath())); if($res){ $data = [ 'code' => 0, 'msg' => '上传成功', 'data' => $newFile, 'url' => '/uploads/'.$filename.'/'.$year.'/'.$date.'/'.$newFile, ]; }else{ $data['data'] = $file->getErrorMessage(); } return response()->json($data); }js://普通图片上传 $(".uploadPic").each(function (index,elem) { upload.render({ elem: $(elem) ,url: '{{ route("api.upload") }}' ,multiple: false ,data:{"_token":"{{ csrf_token() }}","filename":'links'} ,done: function(res){ //如果上传失败 if(res.code == 0){ var _li = $(elem).parent('.layui-upload').find('.layui-upload-box .li_thumb_'+index+''); _li.show(); layer.msg(res.msg,{icon:1}); _li.html('<div><img title="点击删除" src="'+res.url+'" /></div><p>上传成功</p>'); $(elem).parent('.layui-upload').find('.thumb_'+index+'').val(res.url); }else { layer.msg(res.msg,{icon:2}); } } }); });html:<div class="layui-form-item"> <label for="" class="layui-form-label">缩略图</label> <div class="layui-input-block"> <div class="layui-upload"> <button type="button" class="layui-btn layui-btn-sm uploadPic"><i class="layui-icon"></i>图片上传</button> <div class="layui-upload-list" > <ul class="layui-upload-box layui-clear"> <li class="li_thumb_0" id="thumb_0" style="@if(isset($links->thumb)) display: block; @else display: none; @endif"><div><img title="点击删除" src="{{$links->thumb??old('thumb')}}" /></div><p>上传成功</p></li> </ul> <input type="hidden" name="thumb" class="layui-upload-input thumb_0" value="{{$links->thumb??old('thumb')}}"> </div> </div> </div> </div>
查看详情点赞评论收藏浏览202023-02-27 19:48:46最近火爆全网的chatGPT,到底是什么?
近日,OpenAI发布的新聊天机器人模型ChatGPT受到了热烈的关注。它能够模拟人类的语言行为,与用户进行自然交互,并且拥有多样的功能,能舞文弄墨、编写代码甚至几乎无所不能,由于该测试目前免费,上线仅5天用户数量就已突破100万,上线两个月,ChatGPT 用户就达到了 1 亿。ChatGPT的出现引发了人们对AI取代人工、AI打败人类等话题的担忧,它有着巨大的商业空间。 ChatGPT是是由人工智能研究实验室OpenAI在2022年11月30日发布的全新聊天机器人模型,一款人工智能技术驱动的自然语言处理工具,它能够通过学习和理解人类的语言来进行对话,不仅上知天文下知地理,知识渊博,还能根据聊天的上下文进行互动,真正像人类一样来聊天交流,但ChatGPT不单是聊天机器人的简单,甚至能完成撰写邮件、视频脚本、文案、翻译、代码等任务。同时也引起无数网友沉迷与ChatGPT聊天,成为大家讨论的火爆话题。 ChatGPT是人工智能研究实验室OpenAI新推出的一种人工智能技术驱动的自然语言处理工具,使用了Transformer神经网络架构,也是GPT-3.5架构,这是一种用于处理序列数据的模型,拥有语言理解和文本生成能力,尤其是它会通过连接大量的语料库来训练模型,这些语料库包含了真实世界中的对话,使得ChatGPT具备上知天文下知地理,还能根据聊天的上下文进行互动的能力,做到与真正人类几乎无异的聊天场景进行交流。ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。让马斯克为之动容暗叹“CHATGPT 好得吓人,我们离强大到危险的人工智能不远了”。 由于ChatGPT太“聪明”,引起无粉网友沉迷与它进行聊天,有人让它帮忙改作业,有人让它扮演虚拟女友、有人让它编写请假理由、有人用它来补习外语,更有人把ChatGPT陪自己演戏。无论是生成小说、疑难解答或者是哲学的问题,ChatGPT都交上几乎完美的答案,令人惊叹不已。ChatGPT 的主要功能:编写和调试计算机程序。创作音乐、电视剧和故事。写学生作文。回答测试题。写诗和歌词。模拟 Linux 系统。聊天对话。玩游戏。......网址:https://openai.com/blog/chatgpt据了解,Chat GPT回答问题和编写代码的水平比人类还高。ChatGPT的能力简直可用“吓人”二字来形容,仿佛只要有它在,人类世界中各种难题都能迎刃而解,真真切切为咱们生活的各方各面提供了无数便利,这也是其迅速大火的原因。
查看详情点赞评论收藏浏览572023-02-28 09:35:43JS中常见的几种错误
1.1、SyntaxError(语法错误)解析代码时发生的语法错误var 1a; //Uncaught SyntaxError: Invalid or unexpected token 变量名错误console.log 'hello'); //Uncaught SyntaxError: Unexpected string 缺少括号1.2、ReferenceError(引用错误)console.log(a); //Uncaught ReferenceError: a is not defined 引用了一个不存在的变量console.log()= 1; //Uncaught ReferenceError: Invalid left-hand side in assignment 将变量赋值给一个无法被赋值的对象1.3、RangeError(范围错误)var a = new Array(-1); //Uncaught RangeError: Invalid array length 超出有效范围1.4、TypeError(类型错误)变量或参数不是预期类型,比如,对字符串、布尔值、数值等原始类型的值使用new命令,就会抛出这种错误,因为new命令的参数应该是一个构造函数。var a = new 123; //Uncaught TypeError: 123 is not a function调用对象不存在的方法var a;a.aa(); //Uncaught TypeError: Cannot read property 'aa' of undefined1.5、URLError(URL错误)与url相关函数参数不正确,主要是encodeURI()、decodeURI()、encodeURIComponent()、decodeURIComponent()、escape()和unescape()这六个函数。decodeURI('%2') //Uncaught URIError: URI malformed1.6、EvalError(eval错误)eval函数没有被正确执行2、手动抛出错误以上这6种派生错误,连同原始的Error对象,都是构造函数。开发者可以使用它们,人为生成错误对象的实例。throw new Error("出错了!"); throw new RangeError("出错了,变量超出有效范围!"); throw new TypeError("出错了,变量类型无效!");上面代码表示新建错误对象的实例,实质就是手动抛出错误。可以看到,错误对象的构造函数接受一个参数,代表错误提示信息(message)。
查看详情点赞评论收藏浏览412023-02-28 10:19:11laravel 连续where查询
laravel 连续查询:$data = $request->all('page_type','page_port','page_domian','is_promote'); $pagelist = PageList::where(function ($query) use ($data) { foreach ($data as $k => $v) { if ($k == 'page_type') { if (!empty($v)) { $query->where('page_type','=',$v); } }elseif ($k == 'page_port'){ if (!empty($v)) { $query->where('page_port','like','%'.$v.'%'); } }elseif ($k == 'page_domian'){ if (!empty($v)) { $query->where('page_domian','like','%'.$v.'%'); } }elseif ($k == 'is_promote'){ if (!empty($v)) { $query->where('is_promote', $v); } } } })->get()->toArray();
查看详情点赞评论收藏浏览382023-02-28 19:30:242023年还有人不知道TypeScript变量声明?
declare声明的变量和模块后,其他地方不需要引入,就可以直接使用了注意我们需要在配置文件下,引入声明文件{ "compilerOptions": { ... "include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.tsx", "src/**/*.vue"] ... }声明一个类型declare type Asd { name: string; }在include包含的文件范围内可以直接使用Asd这个typedeclare声明一个模块declare module '*.css';declare module '*.less';declare module '*.png';这样,我们可以在ts中引入相关的文件而不报错了declare声明一个变量declare var jQuery: (selector: string) => any;// 声明变量直接使用jQuery("#box")声明一个作用域declare namespace API{ interface ResponseObj { ... } ... }注意declare 与export 不要同级使用,不然的话,声明文件就需要导入了在声明文件中 type 与 interface 也可以不用加declare ,效果相同type myType = string | number;// 两者效果相同declare type myType = string | number;readonly用于标记一个属性是只读的,也就是不可修改的。什么时候要用命名空间?如果你发现自己写的功能(函数/类/接口等...)越来越多, 你想对他们进行分组管理就可以用命名空间, 下面先用"类"举例:什么是声明文件?声明文件就是给js代码补充类型标注. 这样在ts编译环境下就不会提示js文件”缺少类型”.Mock模拟接口数据模拟接口数据vue-meta主要用于管理HMTL头部标签,同时也支持SSR。vue-meta有以下特点:在组件内设置 metaInfo,便可轻松实现头部标签的管理metaInfo 的数据都是响应的,如果数据变化,头部信息会自动更新支持 SSR// 这里的?表示这个name属性有可能不存在class A { name?: string } interface B { name?: string }ts 中的type关键字type作用就是给类型起一个新名字,支持基本类型、联合类型、元祖及其它任何你需要的手写类型,常用于\color{red}{联合类型}type test = number; //基本类型 let num: test = 10; type userOjb = {name:string} // 对象 type getName = ()=>string // 函数 type data = [number,string] // 元组 type numOrFun = Second | getName // 联合类型type和interface的区别1、和接口一样,用来描述对象或函数的类型type User = { name: string age: number }; type SetUser = (name: string, age: number)=>void;vue3 中的 hooks 函数相当于 vue2 里面的 mixin 混入,不同在于 hooks 是函数。
查看详情点赞评论收藏浏览482023-03-01 10:16:11震惊,加上这css动画,产品经理直呼溜溜溜
波浪扩展动画 /* css动画 */ @-webkit-keyframes ball-scale-multiple { 0% { -webkit-transform: scale(0); transform: scale(0); opacity: 0; } 5% { opacity: 1; } 100% { -webkit-transform: scale(1); transform: scale(1); opacity: 0; } } @keyframes ball-scale-multiple { 0% { -webkit-transform: scale(0); transform: scale(0); opacity: 0; } 5% { opacity: 1; } 100% { -webkit-transform: scale(1); transform: scale(1); opacity: 0; } } .ball-scale-multiple { position: relative; -webkit-transform: translate(0.2rem,0.14rem); -ms-transform: translate(0.2rem,0.14rem); transform: translate(0.2rem,0.14rem); z-index: 1; } .ball-scale-multiple>div:nth-child(2) { -webkit-animation-delay: 0.2s; animation-delay: 0.2s; } .ball-scale-multiple>div:nth-child(3) { -webkit-animation-delay: 0.4s; animation-delay: 0.4s; } .ball-scale-multiple>div { background-color: rgb(191, 235, 205); width: .15rem; height: .15rem; border-radius: 100%; -webkit-animation-fill-mode: both; animation-fill-mode: both; position: absolute; right: 0rem; top: -0.54rem; opacity: 0; margin: 0; width: .8rem; height: .8rem; -webkit-animation: ball-scale-multiple 1s 0s linear infinite; animation: ball-scale-multiple 1s 0s linear infinite; }光标移动动画@keyframes colorRight { 0% { background-position: -100% 0; } 100% { background-position: 130% 0; } } li:hover { p:first-child { animation: colorRight 1.2s; color: #222; background: @fontColor linear-gradient( -135deg, transparent 25%, transparent 40%, rgba(255, 255, 255, 1) 40%, rgba(255, 255, 255, 1) 60%, transparent 60%, transparent ); background-size: 20px 20px; background-repeat: no-repeat; -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-position: -100% 0; } }边框闪动@keyframes borderRotate { 50% { height: 100%; width: 0; } 100% { height: 100%; width: 100%; } } li:hover { &::before { content: ""; position: absolute; width: 0; height: 0; border-left: 1px solid #98acff; border-bottom: 1px solid #98acff; z-index: 6; left: 0; bottom: 0; animation: borderRotate 0.5s forwards; } &::after { content: ""; position: absolute; width: 0; height: 0; border-top: 1px solid #98acff; border-right: 1px solid #98acff; z-index: 6; right: 0; top: 0; animation: borderRotate 0.5s forwards; } }
查看详情点赞评论收藏浏览412023-03-01 10:27:2160 句唯美古诗词,温柔了时光,惊艳了岁月!(一)
1、烟蓑散响惊诗思,还被乱鸥飞去,秀句难续。——史达祖《八归·秋江带雨》2、不写情词不献诗,一方素帕寄心知。——冯梦龙《山歌》3、在天愿作比翼鸟,在地愿为连理枝。天长地久有时尽,此恨绵绵无绝期。——白居易《长恨歌》4、曾经沧海难为水,除却巫山不是云。——《离思五首》5、相思无因见,怅望凉风前。——李白《折荷有赠》6、众里寻他千百度,蓦然回首,那人却在,灯火阑珊处。——辛弃疾《青玉案·元夕》7、邂逅相遇,与子偕臧。——《诗经·野有蔓草》8、红豆生南国,春来发几枝。——王维《相思》9、西城杨柳弄春柔。动离忧,泪难收。犹记多情,曾为系归舟。——秦观《江城子》10、小轩窗,正梳妆,相顾无言,惟有泪千行。——苏轼《江城子》11、月出皎兮,佼人僚兮,舒窈纠兮,劳心悄兮!月出皓兮,佼人懰兮,舒忧受兮,劳心慅兮!月出照兮,佼人燎兮,舒夭绍兮,劳心惨兮!——《诗经·陈风·月出》12、二十四桥明月夜,玉人何处教吹箫?——杜牧《寄扬州韩绰判官》13、问世间,情为何物,直教生死相许。——元好问《摸鱼儿二首·其一》14、十二阑干水半溪,千红万紫六桥西。两峰黛黯三春梦,一院花飞五夜鸡。鹤到九霄双翮健,书分四体八行齐。道人殷七归何处,百尺高枝莺又啼。——杨继端《闺怨》15、何处合成愁,离人心上秋。——吴文英《唐多令》16、落花风雨更伤春,不如怜取眼前人。——晏殊《浣溪沙》17、无意苦争春,一任群芳妒。——陆游《卜算子》18、十年生死两茫茫,不思量,自难忘。——苏轼《江城子·乙卯正月二十日夜记梦》19、落红不是无情物,化作春泥更护花。——龚自珍《己亥杂诗》20、梅花雪,梨花月,总相思。——张惠言《相见欢·年年负却花期》21、琵琶弦上说相思,当时明月在,曾照彩云归。——晏几道《临江仙》22、鸿雁在云鱼在水,惆怅此情难寄。——晏殊《清平乐》23、问世间,情为何物,直教生死相许?——元好问《摸鱼儿·雁丘词》24、色不迷人人自迷,情人眼里出西施。——黄増《集杭州俗语诗》25、红烛自怜无好计,夜寒空替人垂泪。——晏几道《蝶恋花》26、兽炉沈水烟,翠沼残花片,一行行写入相思传。——张可久《塞鸿秋》27、千里水天一色,看孤鸿明灭。——朱敦儒《好事近》28、望夫处,江悠悠。化为石,不回头。——王建《望夫石》29、盈盈一水间,脉脉不得语。——《迢迢牵牛星》30、直缘感君恩爱一回顾,使我双泪长珊珊。——卢仝《楼上女儿曲》31、世界微尘里,吾宁爱与憎。——李商隐《北青萝》32、锦瑟无端五十弦,一弦一柱思华年。——李商隐《锦瑟》33、四月十七,正是去年今日,别君时。——韦庄《女冠子·四月十七》34、人如风后入江云,情似雨馀黏地絮。——周邦彦《玉楼春》35、休言半纸无多重,万斛离愁尽耐担。——陈蓬姐《寄外二首其二》36、晓看天色暮看云,行也思君坐也思君。——《一剪梅》37、关关雎鸠,在河之洲。窈宨淑女,君子好逑。——佚名《诗经周南关雎》38、只缘感君一回顾,使我思君朝与暮。——《古相思曲》39、此去经年,应是良辰好景虚设。便纵有千种风情,更与何人说。——柳永《雨霖铃》40、教人无处寄相思,落花芳草过前期,没人知。——孙光宪《虞美人·好风微揭帘旌起》41、我欲与君相知,山无陵,江水为竭,冬雷震震夏雨雪,天地合,乃敢与君绝。42、日边消息空沈沈。画眉楼上愁登临。43、商人重利轻别离,前月浮梁买茶去。去来江口守空船,绕船月明江水寒。44、恨君不似江楼月,南北东西,南北东西,只有相随无别离。45、有情皓月怜孤影,无赖闲花照独眠。46、有女同行,颜如舜英。将翱将翔,佩玉将将。彼美孟姜,德音不忘。47、相逢不语,一朵芙蓉著秋雨。小晕红潮,斜溜鬟心只凤翘。待将低唤,直为凝情恐人见。欲诉幽怀,转过回阑叩玉钗。48、北方有佳人,绝世而独立。一顾倾人城,再顾倾人国。49、一见钟情到老,互诉百感衷肠。林中曲径共徜徉。意如河水淌,情似百花香。50、有美人兮,见之不忘,一日不见兮,思之如狂。51、妾似胥山长在眼,郎如石佛本无心。52、看朱成碧思纷纷,憔悴支离为忆君。53、有美人兮,见之不忘;一日不见兮,思之如狂。54、槿花朝开暮还坠,妾身与花宁独异。忆昔相逢俱少年,两情未许谁最先。感君绸缪逐君去,成君家计良辛苦。人事反覆那能知?谗言人耳须臾离。嫁时罗衣羞更著,如今始悟君难托叶。君难托,妾亦不忘旧时约。55、前生缘定今如约,沐浴东风踏雪来。56、曾经沧海难为水,除却巫山不是云。57、杨花榆荚无才思,惟解漫天作雪飞。58、唤起窗前尚宿酲,啼鹃催去又声声。丹青旧誓相如札,禅榻经时杜牧情。别后相思空一水,重来回首已三生。云阶月地依然在,细逐空香百遍行。59、春朝秋夜思君甚,愁见绣屏孤枕。60、蒹葭苍苍,白露为霜,所谓伊人,在水一方。
查看详情点赞评论收藏浏览502023-03-01 19:09:48