《游戏学习》| 微信对话模拟生成器源码分析

news2024/10/2 16:29:30

简介

微信对话生成器,是一款在线微信聊天对话制作的工具,它可以设置苹果或安卓状态栏,包括手机电量、手机时间等,还可以设置不同用户的角色,然后发送文字、语音、红包、转账等多种好玩的功能,可谓是一款娱乐制作神器。

此项目是由HTML\CSS\JS纯前端代码实现的在线web功能小网站。

此软件只用于娱乐使用,切勿用于非法途径,由此产生任何纠纷由使用者本人自己承担,禁止用于各种违法犯罪行为!!

项目结构

js文件夹是游戏事件控制文件

images 文件夹是图片文件

css 文件夹 是网页样式文件

fonts 文件夹 是网页文字字体文件

favicon.png 是网页游戏图标

index.html 是主页面

代码展示

整个项目只有一个html文件,index.html代码如下:

<!DOCTYPE HTML>
<html>
<head>
    <meta charset="UTF-8">
    <title>在线微信对话生成器 - 泰山</title>
    <meta name="keywords" content="免费在线微信对话生成器" />
    <meta name="description" content="在线微信对话生成器是一款在线微信聊天对话制作的工具" />
    <meta name="render" content="webkit">
    <link rel="icon" href="favicon.png">
    <meta content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no" name="viewport">
    <meta content="telephone=no, address=no" name="format-detection">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black-translucent">
    <script type="text/javascript">
        var _path = { images: 'static/app/images' }
        var page = { data: {} }
    </script>
    <link rel="stylesheet" href="static/app/css/zui.min.css">
    <link rel="stylesheet" href="static/app/css/app.css">
    <link rel="stylesheet" href="static/app/css/jquery.range.css">
    <link rel="stylesheet" href="static/app/css/wallet.css">
    <script type="text/javascript" src="static/app/js/common.bundle.js"></script>
    <script type="text/javascript" src="static/app/js/chat.bundle.js"></script>
</head>
<body>
    <div id="vueApp" class="wrapper">
        <div class="container-fluid page-content">
            <div id="pageHeader">微信对话生成器</div>
            <div class="edit-content">
                <div class="tab">
                    <ul class="nav nav-tabs">
                        <li class="active"><a data-tab href="#tabContent1">外观设置</a></li>
                        <li><a data-tab href="#tabContent2">对话设置</a></li>
                    </ul>
                    <div class="tab-content">
                        <div class="tab-pane active" id="tabContent1">
                            <!-- 外观设置 -->
                            <div class="view-setting">
                                <div class="view-set-item">
                                    <span>手机信号:</span>
                                    <select v-model="phone.single" class="form-control">
                                        <option value="1">1格</option>
                                        <option value="2">2格</option>
                                        <option value="3">3格</option>
                                        <option value="4" selected="selected">4格</option>
                                    </select>
                                </div>
                                <div class="view-set-item">
                                    <span>网络信号:</span>
                                    <select v-model="phone.wifi" class="form-control">
                                        <option value="1">wifi</option>
                                        <option value="2">3G</option>
                                        <option value="3">4G</option>
                                        <option value="4">5G</option>
                                    </select>
                                </div>
                                <div class="view-set-item">
                                    <span>wifi信号:</span>
                                    <select v-model="phone.wifi_single" class="form-control">
                                        <option value="1">1格</option>
                                        <option value="2">2格</option>
                                        <option value="3" selected="selected">3格</option>
                                    </select>
                                </div>
                                <div class="view-set-item">
                                    <span>手机时间:</span>
                                    <select v-model="phone.time_hour" class="form-control edit-phone-time-hour"></select>
                                    <select v-model="phone.time_mini" class="form-control edit-phone-time-mini"></select>
                                </div>
                                <div class="view-set-item">
                                    <span>充电中:</span>
                                    <label class="my-radio"><input type="radio" name="charge"v-model="phone.battery_charge" value="1"> 是</label>
                                    <label class="my-radio"><input type="radio" name="charge"v-model="phone.battery_charge" value="0" checked> 否</label>
                                </div>
                                <div class="view-set-item">
                                    <span>手机电量:</span>
                                    <input @change="onBatteryChange($event)" type="range" v-model="phone.battery_amount"
                                        min="0" max="100" value="50" />
                                    &nbsp;&nbsp;&nbsp;{{phone.battery_amount}}%
                                </div>
                                <div class="view-set-item">
                                    <span>听筒模式:</span>
                                    <label class="my-radio"><input type="radio" name="phone-ear" v-model="phone.ear" value="1"> 是</label>
                                    <label class="my-radio"><input type="radio" name="phone-ear" v-model="phone.ear" value="0" checked> 否</label>
                                </div>
                                <div class="view-set-item">
                                    <span>消息数目:</span>
                                    <input type="number" name="phone-msg-count" class="form-control" v-model.number="setting.message">
                                </div>
                                <div class="view-set-item">
                                    <span>聊天标题:</span>
                                    <input type="text" class="form-control" v-model="setting.title">
                                </div>
                                <div class="view-set-item">
                                    <span>语音模式:</span>
                                    <label class="my-radio"><input type="radio" name="phone-voice" v-model="setting.voice" value="1"> 是</label>
                                    <label class="my-radio"><input type="radio" name="phone-voice" v-model="setting.voice" value="0" checked> 否</label>
                                </div>
                                <div class="view-set-item">
                                    <span>聊天背景:</span>
                                    <a class="a-phone-set-bg" href="javascript:;" title="选择背景图">
                                        <font>+</font>
                                        <img class="img-phone-set-bg" :src="setting.background" />
                                        <input @change="setBackground($event)" type="file" />
                                        <span @click="deleteBackground" v-if="setting.background != ''">x</span>
                                    </a>
                                </div>
                            </div>
                        </div>
                        <!-- 对话设置 -->
                        <div class="tab-pane" id="tabContent2">
                            <div class="dialog-user">
                                <div class="dialog-user-title">编辑和选择用户(<font>第一个用户默认是自己,点击图像可更换</font>)</div>
                                <div class="dialog-user-items">
                                    <div class="dialog-user-item el-remove">
                                        <div class="dialog-user-face">
                                            <a class="dialog-user-face-a" href="javascript:;">
                                                <input type="file" placeholder="点击更换头像">
                                                <i></i>
                                            </a>
                                            <input type="text" value="微信对话生成器" />
                                            <a class="dialog-user-select">选择用户</a>
                                            <a class="dialog-user-delete">x</a>
                                        </div>
                                    </div>
                                    <div class="dialog-user-item el-remove">
                                        <div class="dialog-user-face">
                                            <a class="dialog-user-face-a" href="javascript:;">
                                                <input type="file" placeholder="点击更换头像">
                                                <i></i>
                                            </a>
                                            <input type="text" value="马先生" />
                                            <a class="dialog-user-select">选择用户</a>
                                            <a class="dialog-user-delete">x</a>
                                        </div>
                                    </div>
                                    <div v-for="(user, index) in users" class="dialog-user-item">
                                        <div class="dialog-user-face">
                                            <a class="dialog-user-face-a" href="javascript:;">
                                                <input @change="setUserImage($event, index)" type="file"
                                                    placeholder="点击更换头像">
                                                <i :style="'background-image: url(' + user.image + ')'"></i>
                                            </a>
                                            <input type="text" v-model="user.name" />
                                            <a @click="selectUser(index)"
                                                :class="['dialog-user-select', {'dialog-user-selected':user.selected}]">选择用户</a>
                                            <a v-if="!user.is_me" @click="delUser(index)" class="dialog-user-delete"
                                                title="删除用户">x</a>
                                        </div>
                                    </div>
                                    <div class="dialog-user-item">
                                        <a @click="addUser" class="dialog-user-item-add" href="javascript:;"
                                            title="添加用户">+</a>
                                    </div>
                                </div>

                                <div class="dialog-user-content-title">发送人:{{getSender()}}</div>
                                <div class="dialog-user-content">
                                    <div class="dialog-user-content-panel">
                                        <textarea v-model="setting.dialog_content"
                                            class="edit-dialog-text form-control"></textarea>
                                    </div>
                                    <div class="view-setting view-setting2">
                                        <div class="view-set-item">
                                            <span>红包或转账金额:</span>
                                            <input v-model.number="setting.dialog_money" type="number"
                                                class="form-control">
                                        </div>
                                        <div class="view-set-item">
                                            <span>添加聊天时间:</span>
                                            <select v-model="setting.date_year"
                                                class="form-control edit-phone-time-year">
                                                <option value="">-</option>
                                            </select>
                                            <select v-model="setting.date_month"
                                                class="form-control edit-phone-time-month" style="width: 60px;">
                                                <option value="">-</option>
                                            </select>
                                            <select v-model="setting.date_day" class="form-control edit-phone-time-day"
                                                style="width: 60px;">
                                                <option value="">-</option>
                                            </select>
                                            <select v-model="setting.date_xinqi" class="form-control">
                                                <option value="">-</option>
                                                <option value="星期一">星期一</option>
                                                <option value="星期二">星期二</option>
                                                <option value="星期三">星期三</option>
                                                <option value="星期四">星期四</option>
                                                <option value="星期五">星期五</option>
                                                <option value="星期六">星期六</option>
                                                <option value="星期日">星期日</option>
                                            </select>
                                            <select v-model="setting.date_shiduan" class="form-control"
                                                style="width: 60px;">
                                                <option value="">-</option>
                                                <option value="上午">上午</option>
                                                <option value="下午">下午</option>
                                                <option value="凌晨">凌晨</option>
                                            </select>
                                            <select v-model="setting.date_hour"
                                                class="form-control edit-phone-time-hour" style="width: 60px;">

                                            </select>
                                            :
                                            <select v-model="setting.date_min" class="form-control edit-phone-time-mini"
                                                style="width: 60px;">

                                            </select>
                                        </div>
                                        <div class="view-set-item">
                                            <span>语音时间:</span>
                                            <input v-model.number="setting.dialog_voice" type="number"
                                                class="form-control">
                                            &nbsp;&nbsp;&nbsp;
                                            <label>是否已读:</label>
                                            <label class="my-radio"><input type="radio"
                                                    v-model="setting.dialog_voice_isread" value="1" checked>
                                                是</label>
                                            <label class="my-radio"><input type="radio"
                                                    v-model="setting.dialog_voice_isread" value="0"> 否</label>
                                        </div>
                                        <div class="view-set-item">
                                            <span>红包备注:</span>
                                            <input v-model="setting.dialog_repacket_remark" type="text"
                                                class="form-control">
                                        </div>
                                        <div class="view-set-item">
                                            <span>转账备注:</span>
                                            <input v-model="setting.dialog_trans_remark" type="text"
                                                class="form-control">
                                        </div>
                                    </div>
                                    <div class="btn-groups">
                                        <div class="btn-group">
                                            <button @click="addTextDialog" class="btn btn-success">添加文字对话</button>
                                            <button @click="addNoticeDialog" class="btn btn-primary">添加时间</button>
                                            <button class="btn btn-primary btn-send-image">添加图片对话<input
                                                    @change="addImageDialog($event)" type="file"></button>

                                        </div>
                                        <div class="btn-group">
                                            <button @click="addVoiceDialog" class="btn btn-primary">添加语音对话</button>
                                            <button @click="addRedpacketDialog" class="btn btn-primary">添加红包对话</button>
                                            <button @click="addTransferDialog" class="btn btn-primary">添加转账对话</button>
                                        </div>
                                    </div>
                                    <button class="btn-clear" @click="cleanDialogs" href="javascript:;">清空聊天内容</button>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
                <!-- phone -->
                <div class="phone-wrap">
                    <div class="phone-content">
                        <div id="phone" class="phone">
                            <div class="phone-top">
                                <div class="phone-bar">
                                    <div class="phone-time">{{phone.time_hour}}:{{phone.time_mini}}</div>
                                    <div
                                        :class="['phone-sigle', {'phone-sigle-v1':phone.single == 1}, {'phone-sigle-v2':phone.single == 2}, {'phone-sigle-v3':phone.single == 3}, {'phone-sigle-v4':phone.single == 4}]">
                                        信号</div>
                                    <div
                                        :class="['phone-wifi', {'phone-wifi-v2':phone.wifi > 1}, phone.wifi == 1 ? 'phone-wifi-s' + phone.wifi_single : '']">
                                        <template v-if="phone.wifi == 1">
                                            wifi
                                        </template>
                                        <template v-else-if="phone.wifi == 2">
                                            3G
                                        </template>
                                        <template v-else-if="phone.wifi == 3">
                                            4G
                                        </template>
                                        <template v-else-if="phone.wifi == 4">
                                            5G
                                        </template>
                                    </div>
                                    <div :class="['phone-battery', {'phone-battery-charge':phone.battery_charge == 1}]">
                                        <span>
                                            <font :style="[{width: phone.battery_amount + '%'}]">电量</font>
                                            <i></i>
                                        </span>
                                    </div>
                                </div>
                                <div class="phone-nav">
                                    <div class="phone-nav-left">
                                        <div class="phone-nav-back">返回</div>
                                        <span v-if="setting.message && setting.message > 0">{{setting.message}}</span>
                                    </div>
                                    <div class="phone-nav-center">
                                        <span>
                                            <font>{{setting.title}}</font>
                                            <i v-if="phone.ear == 1"></i>
                                        </span>
                                    </div>
                                    <div class="phone-nav-right">
                                        <div class="phone-nav-more">更多</div>
                                    </div>
                                </div>
                            </div>

                            <div class="phone-bg">
                                <img @load="onBackgroundLoad($event)" :src="setting.background" />
                            </div>

                            <div class="phone-water"></div>

                            <div class="phone-body">
                                <div class="wechat-content">
                                    <template v-for="(dialog, index) in dialogs">
                                        <div :class="['wechat-dialog', {'wechat-dialog-right':dialog.is_me}]">
                                            <div v-if="dialog.type != 'notice'" class="wechat-dialog-face">
                                                <img :src="getUserById(dialog.user_id).image" />
                                            </div>

                                            <template v-if="dialog.type == 'text'">
                                                <div class="wechat-dialog-text">{{dialog.content}}</div>
                                            </template>

                                            <template v-if="dialog.type == 'image'">
                                                <div
                                                    :class="['wechat-dialog-text', 'wechat-dialog-image', {'wechat-dialog-image-noborder':setting.background != ''}]">
                                                    <img :src="dialog.image">
                                                </div>
                                            </template>

                                            <template v-if="dialog.type == 'voice'">
                                                <div class="wechat-dialog-text wechat-dialog-voice">
                                                    <div v-if="dialog.is_me"
                                                        :style="{width: getVoiceLength(dialog.time) + 'px'}"></div>
                                                    <span v-if="dialog.is_me">{{dialog.time}}"</span>
                                                    <i></i>
                                                    <span v-if="!dialog.is_me">{{dialog.time}}"</span>
                                                    <div v-if="!dialog.is_me"
                                                        :style="{width: getVoiceLength(dialog.time) + 'px'}"></div>
                                                    <em v-if="!dialog.is_me && dialog.isread == '0'"></em>
                                                </div>
                                            </template>

                                            <template v-if="dialog.type == 'notice'">
                                                <div class="wechat-dialog-notice">
                                                    <span
                                                        :class="[{'wechat-dialog-notice-has-bg':setting.background != ''},{'wechat-dialog-notice-system':dialog.is_system}]"
                                                        v-html="dialog.content"></span>
                                                </div>
                                            </template>

                                            <template v-if="dialog.type == 'transfer' || dialog.type == 'redpacket'">
                                                <div
                                                    :class="['wechat-dialog-text', 'wechat-dialog-trans', {'wechat-dialog-trans-get':dialog.is_get}]">
                                                    <div
                                                        :class="['wechat-dialog-trans-content', {'wechat-dialog-redp-content':dialog.type == 'redpacket'}]">
                                                        <i></i>
                                                        <div>
                                                            <span
                                                                v-if="dialog.type == 'transfer'">¥{{moneyFormat(dialog.money,
                                                                2, '', false)}}</span>
                                                            <font v-if="dialog.type == 'transfer'">{{dialog.remark}}
                                                            </font>
                                                            <span
                                                                v-if="dialog.type == 'redpacket'">{{dialog.remark}}</span>
                                                            <font v-if="dialog.type == 'redpacket' && dialog.is_get">
                                                                已领取</font>
                                                        </div>
                                                    </div>
                                                    <div class="wechat-dialog-trans-bottom">
                                                        <span v-if="dialog.type == 'transfer'">微信转账</span>
                                                        <span v-if="dialog.type == 'redpacket'">微信红包</span>
                                                    </div>
                                                </div>
                                            </template>

                                            <a @click="deleteDialog(index)" class="a-wechat-dialog-del"
                                                href="javascript:;" title="删除对话">X</a>

                                            <div v-if="!dialog.is_get && dialog.type == 'redpacket'"
                                                class="a-wechat-dialog-menu">
                                                <a @click="redpacketGet(index)">领取</a>
                                            </div>
                                            <div v-if="!dialog.is_get && dialog.type == 'transfer'"
                                                class="a-wechat-dialog-menu">
                                                <a @click="transferGet(index)">领取</a>
                                            </div>
                                        </div>
                                    </template>
                                </div>
                            </div>

                            <div class="phone-bottom">
                                <div class="phone-bottom-chat">
                                    <div class="wechat-bottom">
                                        <div
                                            :class="['wechat-bottom-icon', 'wechat-voice-icon', {'wechat-voice-say-icon':setting.voice == 1}]">
                                            语音</div>
                                        <div :class="['wechat-input', {'wechat-input-say':setting.voice == 1}]">
                                            <template v-if="setting.voice == 1">按住 说话</template>
                                            <template v-else>输入框</template>
                                        </div>
                                        <div class="wechat-bottom-icon wechat-emoji-icon">表情</div>
                                        <div class="wechat-bottom-icon wechat-more-icon">更多功能</div>
                                    </div>
                                </div>
                                <div class="phone-bottom-bar">
                                    <i>返回桌面</i>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </div>
</body>

</html>

wallet.css 网页程序样式控制 (其他文件代码太多,粘贴后直接卡死,不过多展示)

.wallet .wallet-list {
    display: flex;
    flex-direction: row;
}
.wallet .wallet-list .list-item {
    flex: 1;
    text-align: center;
}
.wallet .wallet-list .item-logo {
    width: 60px;
    height: 60px;
}
.wallet .wallet-list .item-name {
    font-size: 14px;
}
.wallet .wallet-service {
    margin: 15px 0;
    font-size: 16px;
}
.wallet .wallet-service span {
    color: red;
}

项目运行

启动方式 ,tomcat/nginx 等服务器部署,或者浏览器直接打开index.html。

可以利用gitee page 或者github page 免费外网部署。

游戏截图

游戏完整源码下载

https://download.csdn.net/download/weixin_40986713/87446227

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/347959.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

es的使用与原理8 -- 初识es及es简单CRUD语法

为什么不能使用数据库做搜索&#xff1f; 1、比方说&#xff0c;每条记录的指定字段的文本&#xff0c;可能会很长&#xff0c;比如说“商品描述”字段的长度&#xff0c;有长达数千个&#xff0c;甚至数万个字符&#xff0c;这个时候&#xff0c;每次都要对每条记录的所有文本…

vue处理一千张图片进行分页加载

vue处理一千张图片进行分页加载 开发过程中&#xff0c;如果后端一次性返回你1000多条图片或数据&#xff0c;那我们前端应该怎么用什么思路去更好的渲染呢&#xff1f; 第一种&#xff1a;我们可以使用分页加载 第二种&#xff1a;我们可以进行懒加载那我们用第一种方法使用…

Mysql 与 磁盘交互的过程

从之前的Mysql架构可以了解到&#xff0c;Mysql 客户端不是直接和磁盘打交道&#xff0c;我们在客户端输入的sql语句会被发送给服务端&#xff0c;服务端对sql语句进行解析、缓存等操作&#xff0c;然后再交由存储引擎去读写磁盘。这其实是从 C/S 的角度去了解Mysql。 站在OS的…

jvm如何判断对象已死?

在堆里面存放着各种各类的Java对象&#xff0c;垃圾收集器在对堆进行垃圾回收时&#xff0c;首要就是判断哪些对象还活着&#xff0c;哪些对象已经死去(即不被任何途径引用的对象)。引用计数器算法&#xff1a;引用计数器算法简单概括为&#xff1a;给对象添加一个引用计数器&a…

Java基础面试题——IO和多线程专题

文章目录1.介绍下进程和线程的关系2.说说Java中实现多线程的几种方法3.如何停止一个正在运行的线程4.介绍下线程中的常用方法1.start方法2.run方法3.getName方法4.优先级5.sleep方法6.isAlive7.join8.yield9.wait和notify/notifyAll5.介绍下线程的生命周期6.为什么wait, notify…

什么?30秒生成一个logo

logo 是徽标或者商标的英文说法。logo 承载着企业的无形资产&#xff0c;是企业综合信息传递的媒介。标志作为企业CIS战略的最主要部分&#xff0c;在企业形象传递过程中&#xff0c;是应用最广泛、出现频率最高&#xff0c;同时也是最关键的元素。通过形象的 logo 可以让消费者…

(考研湖科大教书匠计算机网络)第四章网络层-第三节5:IPv4地址的应用规划

获取pdf&#xff1a;密码7281专栏目录首页&#xff1a;【专栏必读】考研湖科大教书匠计算机网络笔记导航 文章目录一&#xff1a;定长的子网掩码FLSM二&#xff1a;变长的子网掩码VLSM本节对应视频如下 【计算机网络微课堂&#xff08;有字幕无背景音乐版&#xff09;】&#x…

笔记本电脑怎么连接无线网wifi?不同电脑系统的使用教程(2023最新)

现在越多人使用笔记本电脑&#xff0c;在我们的日常生活和工作中是很难离开它的。想要更快速地上网&#xff0c;我们都会选择连接无线网的wifi。有时笔记本电脑无法连接网络&#xff0c;你知道这是什么原因吗&#xff1f;笔记本电脑怎么连接无线网wifi&#xff1f;方法很简单&a…

.NET C# 世界日期格式转换为yyyyMMdd

本文分享了一个按照不同国家的语言生成相应时间格式的案例&#xff0c;有需要做国外网站或者多国语言网站的朋友可以参考一下。 本文在引用 【C# DateTime.ToString根据不同语言生成相应的时间格式】基础上做了一个Demo测试&#xff0c;旨在给更多有需要的人能刷到 官方示例&…

蓝奏云网盘下载链接无法打开的解决方法(详解 全)

&#x1f388;前言蓝奏云是一家国内的比较有良心的网盘提供商&#xff0c;提供有不限量的网盘空间&#xff0c;且不限制下载速度&#xff0c;免费用户只限制上传单文件小于100M的文件。算是比较有良心的。而且下载还不用登录才能下载&#xff08;很多标称免费的网盘均需要下载者…

Python进阶篇(二)-- Django 深入模型

上一节提到了Django是基于MVC架构的Web框架&#xff0c;MVC架构追求的是“模型”和“视图”的解耦合。所谓“模型”说得更直白一些就是数据&#xff08;的表示&#xff09;&#xff0c;所以通常也被称作“数据模型”。在实际的项目中&#xff0c;数据模型通常通过数据库实现持久…

阿里云部署SpringBoot项目

目录 步骤1&#xff1a;购买服务器(新用户免费试用一个月) 步骤2&#xff1a;查看服务器相关信息 ​编辑 步骤3&#xff1a;设置安全组 步骤4&#xff1a;远程连接 步骤5&#xff1a;使用FinalShell连接阿里云服务器 步骤6&#xff1a;阿里云服务器上安装JDK ​编辑 步骤7…

Inception Transformer

paper链接: https://arxiv.org/abs/2205.12956v2 code链接: https://github.com/sail-sg/iFormer Inception Transformer一、引言二、实现细节三、实验一、分类二、检测三、分割四、消融实验一、引言 最近的研究表明&#xff0c;Transformer具有很强的建立远程依赖关系的能力…

vAPI:一个自托管的OWASP Top 10漏洞API靶场

关于vAPI vAPI是一款针对OWASP Top 10漏洞的练习靶场&#xff0c;vAPI项目是一个故意引入了多种漏洞的可编程接口API&#xff0c;广大研究人员可以利用vAPI来研究和练习OWASP Top 10漏洞。 工具要求 PHP MySQL PostMan Mitmproxy 工具安装 Docker安装 docker-compose up -d…

Jira和Confluence Server版终止支持倒计时365天,企业应对策略汇总

本文对Atlassian最新的Server版政策进行了解读&#xff0c;并给出应对方案&#xff1b;同时我们也将国内热门的替代工具与jira进行了比较细致的对比&#xff0c;以及介绍替换的优惠政策等。今天是2023年2月15日&#xff0c;距离 Atlassian 旗下 Jira、Confluence 等系列产品中国…

互联网的路由选择协议

互联网的路由选择协议 文章目录互联网的路由选择协议路由选择协议的几个概念分层次路由选择协议内部网关协议RIP协议距离向量算法RIP协议的报文格式内部网关协议OSPFOSPF的报文格式✨OSPF的特点外部网关协议BGPBGP的报文格式参考本篇主要讨论的是路由表中的路由是如何得出来的。…

如何获取 openai ChatGPT的key?(图文教学)

我直接对他进行询问 Q&#xff1a;获取chatptp的key A&#xff1a;对不起&#xff0c;作为ChatGPT&#xff0c;我不具有API密钥或访问凭据。我只是一个已经被训练好的自然语言处理模型&#xff0c;通过输入文本来生成回复。您可以在OpenAI的网站上了解有关他们的API和访问凭据…

Gif动态图片怎样在线生成?一招快速完成gif在线制作

Gif表情包作为日常聊天中必备的气氛调和剂&#xff0c;不仅能够更好的表达出自己的内心情绪&#xff0c;还能够缓解聊天的尴尬。那么&#xff0c;要怎么制作gif表情包呢&#xff1f;下面&#xff0c;介绍两个简单的方法&#xff0c;轻松一键就能在线完成gif制作&#xff08;htt…

Linux安装elasticsearch-head

elasticsearch-head 是一款专门针对于 elasticsearch 的客户端工具&#xff0c;用来展示数据。 elasticsearch-head 是基于 JavaScript 语言编写的&#xff0c;可以使用 Nodejs 下的包管理器 npm 部署。 1 安装Nodejs nodejs下载地址&#xff1a; https://nodejs.org/en/dow…

记一次OOM

1,问题描述&#xff1a; 新上了一版代码之后&#xff0c;上游服务请求我们服务失败&#xff0c;报错&#xff1a;“服务不可用”&#xff0c;发现注册中心上服务掉线&#xff0c;查询日志&#xff1a;发现oom&#xff1a;Java heap space,GC overhead limit exceeded。 容易…