民宿管理系统6

普通管理员管理:

新增普通管理员:

前端效果:

前端代码:

<body>
<div class="layui-fluid"><div class="layui-row"><div class="layui-form"><div class="layui-form-item"><label for="loginname" class="layui-form-label"><span class="x-red">*</span>登录名</label><div class="layui-input-inline"><input type="text" id="loginname" name="loginname" lay-verify="required|loginname" class="layui-input"></div></div><div class="layui-form-item"><label for="L_loginpassword" class="layui-form-label"><span class="x-red">*</span>设置登录密码</label><div class="layui-input-inline"><input type="password" id="L_loginpassword" name="loginpassword" lay-verify="required|loginpassword" class="layui-input"></div></div><div class="layui-form-item"><label for="L_confirmloginpassword" class="layui-form-label"><span class="x-red">*</span>确认密码</label><div class="layui-input-inline"><input type="password" id="L_confirmloginpassword" name="confirmloginpassword" lay-verify="required|confirmloginpassword" class="layui-input"></div></div><div class="layui-form-item"><label class="layui-form-label"></label><button class="layui-btn" lay-filter="submit" lay-submit="">保存</button></div></div></div>
</div><script>layui.use(['form', 'layer', 'upload'], function () {$ = layui.jquery;var form = layui.form,upload = layui.upload,layer = layui.layer;//自定义验证规则form.verify({loginname: function (value) {var code;$.ajax({url: "/smalladmin/checkloginname",type: "GET",async: false,  //关闭异步,当success返回结果后才执行ajax之后的内容data: {"loginname": value},success: function (s) {code = s;}});if (code != true) {return '登录名重复,请重新输入!';}},loginpassword: [/(.+){6,12}$/, '密码必须6到12位'],confirmloginpassword: function () {if ($('#L_confirmloginpassword').val() != $('#L_loginpassword').val()) {return '两次密码不一致';}}});//监听提交form.on('submit(submit)', function (data) {console.log(data.field);$.ajax({url: "/smalladmin/addadmin",type: "post",data: data.field,success: function (s) {if (s == true) {layer.alert("新增普通管理员信息成功!", {icon: 6}, function () {parent.layer.closeAll();parent.location.href = "/admin/sysindex";});} else {layer.msg("登录名重复!", function () {});}},error: function () {layer.msg("接口异常!", function () {});}});});});
</script></body>

后端代码:

SmalladminController
/*** 超级管理员,新增普通管理员页面*/@GetMapping("/addadminpage")public String adduserpage() {return "smalladmin/addadminpage";}/*** 超级管理员新增普通管理员,判断新增普通管理员登录名是否重复*/@GetMapping("/checkloginname")@ResponseBodypublic boolean checkaddadminloginname(@RequestParam("loginname") String loginname) {return smalladminService.checkaddadminloginname(loginname);}/*** 超级管理员新增普通管理员信息*/@PostMapping("/addadmin")@ResponseBodypublic boolean addadmin(@RequestParam("loginname") String loginname,@RequestParam("loginpassword") String loginpassword,@RequestParam("confirmloginpassword") String confirmloginpassword) {return smalladminService.addadmin(loginname,loginpassword);}@GetMapping("/updateadminpage")public String updateadminpage() {return "smalladmin/updateadminpage";}
SmalladminService
/*** 超级管理员新增普通管理员,判断新增普通管理员登录名是否重复*/boolean checkaddadminloginname(String loginname);/*** 超级管理员新增普通管理员信息*/boolean addadmin(String loginname, String loginpassword);
SmalladminServicelpml
/*** 超级管理员新增普通管理员,判断新增普通管理员登录名是否重复*/@Overridepublic boolean checkaddadminloginname(String loginname) {Smalladmin smalladmin=smalladminMapper.selectaddadminloginname(loginname);return smalladmin==null;}/*** 超级管理员新增普通管理员信息*/@Overridepublic boolean addadmin(String loginname, String loginpassword) {return smalladminMapper.addsmalladmin(loginname,loginpassword);}
SmalladminMapper
/*** 超级管理员新增普通管理员时,检查登录名是否重复* @param loginname* @return*/Smalladmin selectaddadminloginname(String loginname);/*** 超级管理员新增普通管理员信息* @param loginname* @param loginpassword* @return*/boolean addsmalladmin(@Param("loginname") String loginname,@Param("loginpassword") String loginpassword);

SmalladminMapper.xml

  <select id="selectaddadminloginname" resultType="com.homestay.pojo.Smalladmin">select<include refid="Base_Column_List"></include>from smalladminwhere sname=#{loginname}</select><insert id="addsmalladmin">insert into smalladmin(sname,spassword)values (#{loginname},#{loginpassword})</insert>

测试:

登录名重复:

必填项为空:

两次密码不一样:

新增成功:

普通管理员分页查询:

前端效果:

前端代码:

<body>
<div class="layui-fluid"><div class="layui-row layui-col-space15"><div class="layui-col-md12"><div class="layui-card"><div class="layui-card-body "><form class="layui-form layui-col-space5"><div class="layui-inline layui-show-xs-block"><input type="text" name="dname" placeholder="管理员名称" autocomplete="off" class="layui-input"></div><div class="layui-inline layui-show-xs-block"><button class="layui-btn" lay-submit="" lay-filter="search_btn"><i class="layui-icon">&#xe615;</i></button></div><a class="layui-btn layui-btn-small" style="line-height:1.6em;margin-top:3px;float:right" onclick="reload();" title="刷新"><i class="layui-icon layui-icon-refresh" style="line-height:30px"></i></a></form></div><div class="layui-card-body "><table id="departmenList" lay-filter="departmenList"></table></div></div></div></div>
</div><script type="text/html" id="departmenListBar"><a class="layui-btn layui-btn-xs" lay-event="edit" >编辑</a><a class="layui-btn layui-btn-xs layui-btn-danger" lay-event="del">删除</a>
</script><script type="text/javascript" th:inline="javascript">layui.use(['form', 'layer', 'table'], function () {var form = layui.form,layer = layui.layer,$ = layui.jquery,table = layui.table;var tableIns = table.render({elem: '#departmenList',url: '/smalladmin/pagequarysmalladmin',method: 'get',title: '管理员列表',page: true,  //开启分页height: "full-110",  //高度最大化减去差值110,高度将始终铺满// toolbar: true,  //开启工具栏limit:10,  //每页显示的条数limits: [5,10,20,30],  //每页条数的选择项cols:[[{type: 'checkbox', field: 'sid', fixed: "left"},{field: 'sid', title: '普通管理员id', align: "center", unresize: "true"},{field: 'sphoto',title: '普通管理员头像',align: 'center',unresize: "true",templet: function(d) {// 如果 uphoto 是图片URL,直接渲染为 <img> 标签return '<img src="' + d.sphoto + '" style="width: 40px; height: 40px; border-radius: 50%;" />';}},{field: 'sname', title: '普通管理员名称', align: 'center', unresize: "true"},{field: 'spassword',title: '普通管理员密码',align: 'center',unresize: "true"},{title: '操作', align: "center", unresize: "true", toolbar: "#departmenListBar"}]]});//搜索form.on('submit(search_btn)', function (data) {tableIns.reload({url: '/smalladmin/listbyname',where: data.field, page: {curr: 1 //重新从第 1 页开始}});return false;});//监听工具条table.on('tool(departmenList)', function (obj) {var data = obj.data, //获得当前行数据layEvent = obj.event; //获得 lay-event 对应的值(也可以是表头的 event 参数对应的值)switch (layEvent) {case 'del':layer.confirm('确定删除此管理员?', {icon: 3, title: '提示信息'}, function (index) {$.post("/smalladmin/delete",{// "nid": $('#nid').val()"sid":data.sid},function (success) {  // 直接接收布尔值if (success) {layer.msg('删除管理员成功', {icon: 1});// 删除成功后刷新父窗口setTimeout(function() {xadmin.father_reload();}, 1000);} else {layer.msg('删除管理员失败', {icon: 2});}});layer.close(index);});return false;// 阻止默认行为break;// case 'edit'://     xadmin.open('管理员编辑', '/admin/checkadminpasswordpage?gid=' + data.gid, 450, 300);//     break;case 'edit':// 构造完整的编辑URL,包含所有参数var editUrl = '/smalladmin/updatesmalladminpage?sid=' + data.sid+ '&sphoto=' + encodeURIComponent(data.sphoto || '')+ '&sname=' + encodeURIComponent(data.sname || '')+ '&spassword=' + encodeURIComponent(data.spassword || '');// 打开编辑窗口(调整弹窗大小以适应内容)xadmin.open('普通员工编辑', editUrl, 800, 550);break;default:break;}});});function reload() {$.get("/smalladmin/reload", function (data) {if (data) {location.reload();} else {parent.location.reload();}});}
</script>
</body>

后端代码:

SmalladminController:
/*** 超级管理员编辑普通管理员,分页查询*/@GetMapping("/pagequarysmalladmin")@ResponseBodypublic Result pagequarysmalladmin(@RequestParam Map<String,Object> map) {int page = Integer.parseInt(map.get("page").toString());int limit = Integer.parseInt(map.get("limit").toString());int start=(page-1)*limit;return smalladminService.getsmalladminList(start,limit);}
SmalladminService
/*** 分页查询普通管理员* @param start* @param limit* @return*/Result getsmalladminList(int start, int limit);
SmalladminServicelpml
/*** 分页查询普通管理员* @param start* @param limit* @return*/@Overridepublic Result getsmalladminList(int start, int limit) {int countsmalladmin=smalladminMapper.countsmalladmin();List<Smalladmin> smalladmins=smalladminMapper.selectsmalladmin(start,limit);Result result=new Result();result.setData(smalladmins);result.setCount(countsmalladmin);result.setMsg("查询成功");result.setCode(0);return result;}
SmalladminMapper:
 /*** 获取普通管理员总数* @return*/int countsmalladmin();/*** 分页查询,获取数据* @param start* @param limit* @return*/List<Smalladmin> selectsmalladmin(@Param("start") int start, @Param("limit") int limit);

SmalladminMapper.xml

  <select id="countsmalladmin" resultType="java.lang.Integer">select count(*) from smalladmin</select><select id="selectsmalladmin" resultType="com.homestay.pojo.Smalladmin">select<include refid="Base_Column_List"></include>from smalladminorder by sidlimit #{start},#{limit}</select>

测试:

一页5条:

一页10条:

模糊查询:

后端代码:

SmalladminController
 /*** 模糊查询*/@GetMapping("/listbyname")@ResponseBodypublic Result listbyname(@RequestParam Map<String,Object> map) {int page = Integer.parseInt(map.get("page").toString());int limit = Integer.parseInt(map.get("limit").toString());int start=(page-1)*limit;String dname=map.get("dname").toString();return smalladminService.listbyname(dname,start,limit);}
SmalladminService
/*** 模糊查询* @param dname* @param start* @param limit* @return*/Result listbyname(String dname, int start, int limit);
SmalladminServicelpml
 /*** 模糊查询* @param dname* @param start* @param limit* @return*/@Overridepublic Result listbyname(String dname, int start, int limit) {int countsmalladmin=smalladminMapper.countsmalladminbyname(dname);List<Smalladmin> smalladmins=smalladminMapper.selectsmalladminbyname(dname,start,limit);Result result=new Result();result.setData(smalladmins);result.setCount(countsmalladmin);result.setMsg("查询成功");result.setCode(0);return result;}
SmalladminMapper
/*** 模糊查询获取名总数* @param dname* @return*/int countsmalladminbyname(@Param("dname") String dname);/*** 模糊查询* @param dname* @param start* @param limit* @return*/List<Smalladmin> selectsmalladminbyname(@Param("dname") String dname, @Param("start") int start, @Param("limit") int limit);
 SmalladminMapper.xml
    <select id="countsmalladminbyname" resultType="java.lang.Integer">select count(*)from smalladminwhere sname like concat('%',#{dname},'%')</select><select id="selectsmalladminbyname" resultType="com.homestay.pojo.Smalladmin">select<include refid="Base_Column_List"></include>from smalladminwhere sname like concat('%',#{dname},'%')order by sidlimit #{start},#{limit}</select>

测试:

删除普通管理员

后端代码:

SmalladminController
/*** 删除普通管理员* @param sid* @return*/@PostMapping("/delete")@ResponseBodypublic boolean delete(@RequestParam("sid") int sid) {return smalladminService.deletesmalladmin(sid);}
SmalladminService
/*** 删除普通管理员* @param sid* @return*/boolean deletesmalladmin(int sid);
SmalladminServicelpml
/*** 删除普通管理员* @param sid* @return*/@Overridepublic boolean deletesmalladmin(int sid) {return smalladminMapper.deletesmalladmin(sid);}
SmalladminMapper
/*** 删除普通管理员* @param sid* @return*/boolean deletesmalladmin(int sid);
SmalladminMapper.xml
  <delete id="deletesmalladmin">delete from smalladminwhere sid = #{sid,jdbcType=INTEGER}</delete>

测试

编辑普通管理员:

前端效果

前端代码

<body>
<div class="layui-fluid"><div class="layui-row"><div class="layui-form"><div class="layui-form-item"><label class="layui-form-label">普通管理员头像</label><div class="img-upload-area"><img class="layui-upload-img" id="nphoto" th:src="${session.smallphoto}"><div class="upload-btn-group"><button type="button" class="layui-btn layui-btn-primary" id="choiceImg"><i class="layui-icon">&#xe67c;</i>选择图片</button><button type="button" class="layui-btn" id="uploadImg"><i class="layui-icon">&#xe67c;</i>上传图片</button></div></div><p id="uploadErrorText" style="margin-left: 120px; color: var(--error-color);"></p></div><div class="layui-form-item"><label for="sid" class="layui-form-label"><span class="x-red">*</span>普通管理员id</label><div class="layui-input-inline"><input type="text" id="sid" name="sid" class="layui-input" readonly="readonly" th:value="${session.sid}"></div></div><div class="layui-form-item"><label for="updatesmallname" class="layui-form-label"><span class="x-red">*</span>修改登录名</label><div class="layui-input-inline"><input type="text" id="updatesmallname" name="updatesmallname" lay-verify="required|loginname" class="layui-input" th:value="${sname}"></div></div><div class="layui-form-item"><label for="updatesmallloginpassword" class="layui-form-label"><span class="x-red">*</span>修改登录密码</label><div class="layui-input-inline"><input type="password" id="updatesmallloginpassword" name="updatesmallloginpassword" lay-verify="required|updatesmallloginpassword" class="layui-input" th:value="${spassword}"></div></div><div class="layui-form-item"><label for="confirmloginpassword" class="layui-form-label"><span class="x-red">*</span>确认密码</label><div class="layui-input-inline"><input type="password" id="confirmloginpassword" name="confirmloginpassword" lay-verify="required|confirmloginpassword" class="layui-input"></div></div><div class="layui-form-item"><label class="layui-form-label"></label><button class="layui-btn" lay-filter="submit" lay-submit="" id="submit"><i class="layui-icon">&#xe605;</i> 保存修改</button></div></div></div>
</div>
<script>layui.use(['form', 'layer', 'upload'], function () {$ = layui.jquery;var form = layui.form,upload = layui.upload,layer = layui.layer;// 表单验证form.verify({required: function(value) {if(value.trim() === '') {return '此项不能为空';}}});//选完文件后不自动上传var uploadInst = upload.render({elem: '#choiceImg',url: '/smalladmin/upload/updatesmalladminphoto',auto: false,bindAction: '#uploadImg',choose: function (obj) {obj.preview(function (index, file, result) {$('#nphoto').attr('src', result);});},before: function() {layer.load(1, {shade: [0.1, '#fff']});},done: function (res) {layer.closeAll('loading');if (res == true) {layer.msg('上传成功', {icon: 1});} else {layer.msg('上传失败', {icon: 2});}},error: function () {layer.closeAll('loading');var uploadErrorText = $('#uploadErrorText');uploadErrorText.html('<span style="color: var(--error-color);">上传失败,请重试</span>');}});//自定义验证规则form.verify({// oldPwd: function (value) {//     var code;//     $.ajax({//         url: "/admin/password",//         type: "GET",//         async: false,  //关闭异步,当success返回结果后才执行ajax之后的内容//         data: {"oldPwd": value},//         success: function (s) {//             code = s;//         }//     });//     if (code != true) {//         return '旧密码错误,请重新输入!';//     }// },updatesmallloginpassword: [/(.+){6,12}$/, '密码必须6到12位'],confirmloginpassword: function () {if ($('#updatesmallloginpassword').val() != $('#confirmloginpassword').val()) {return '两次密码不一致';}}});//监听提交form.on('submit(submit)', function (data) {var loadIndex = layer.load(2, {shade: [0.1, '#fff']});$.ajax({url: "/smalladmin/updatesmalladmininformation",type: "post",data: data.field,success: function (s) {layer.close(loadIndex);if (s == true) {layer.alert("普通管理员信息修改成功!", {icon: 1,title: '成功',skin: 'layui-layer-molv'}, function () {parent.layer.closeAll();parent.location.reload();});} else {layer.msg("登录名重复,普通管理员信息修改失败!", {icon: 2});}},error: function () {layer.close(loadIndex);layer.msg("请求失败,请检查网络连接", {icon: 2});}});return false;});});
</script>
</body>

后端代码:

SmalladminController
/*** 修改普通管理员页面* @return*/@GetMapping("/updatesmalladminpage")public String updatesmalladminpage(@RequestParam("sid")String sid, @RequestParam("sname")String sname,@RequestParam("spassword")String spassword, HttpSession session,@RequestParam("sphoto")String sphoto, Model model) {model.addAttribute("sid", sid);model.addAttribute("sname", sname);model.addAttribute("spassword", spassword);model.addAttribute("sphoto", sphoto);session.setAttribute("smallphoto",sphoto);session.setAttribute("sid",sid);return "smalladmin/updatesmalladminpage";}/*** 修改普通管理员信息* @param sid* @param sname* @return*/@PostMapping("/updatesmalladmininformation")@ResponseBodypublic boolean updatesmalladmininformation(@RequestParam("sid")String sid,@RequestParam("updatesmallname")String sname,@RequestParam("updatesmallloginpassword")String spassword,HttpSession session){return smalladminService.updatesmalladmin(sid,sname,spassword);}@PostMapping({"/upload/updatesmalladminphoto"})@ResponseBodypublic boolean updatesmalladminphoto(HttpServletRequest request, @RequestParam("file")MultipartFile file, HttpSession session, Model model) throws IOException, URISyntaxException{/*1、给文件起一个新的文件名--------------------*/String suffixName = UploadFileUtils.getSuffixName(file);String newFileName = UploadFileUtils.getNewFileName(suffixName);/*-----------------------------------------*//*2.在本机(或服务器)创建一个文件夹-----------*/String realPath = System.getProperty("user.dir") + "\\upload\\";
//System.getProperty("user.dir")获取该项目在本机上的绝对路径,比如“C:\java\demo”
//realPath:图片在服务器上的物理存储地址,比如“C:\java\demo\\upload”File fileDirectory = new File(realPath); //在内存中创建文件夹映射对象,比如“C:\java\demo\\upload”File destFile = new File(realPath + newFileName); //在内存中创建文件映射对象,比如“C:\java\demo\\upload\xxxx.jpg”if (!fileDirectory.exists() && !fileDirectory.mkdirs()) {System.out.println("文件夹创建失败!");return false;}/*-----------------------------------------*//*3.把file以新文件名形式存入本机(或服务器)文件夹-----*/file.transferTo(destFile);/*----------------------------------------------*//*4.创建能访问该文件的URL地址(不是电脑的物理地址、不是绝对路径)放入数据库表-----*/
//new URI()生成一个统一资源定位地址,例如URL,如果语法不正确则抛出异常URI uri = new URI(request.getRequestURL() + "");
//http://localhost:8081/admin/upload/userImg/uri = UploadFileUtils.getHost(uri); //http://localhost:8081String sqlImg = uri + "/upload/" + newFileName; //sqlImg:存入数据库表中的图片地址,比如“http://localhost:8081/upload/xxxx.jpg”if (smalladminService.updatesmalladminphoto(session.getAttribute("sid").toString(), sqlImg)) {session.setAttribute("smalladminphoto", sqlImg);return true;} else {return false;}/*--------------------------------------------------------------------*/}
SmalladminService
 /*** 修改普通管理员信息* @param sid* @param sname* @param spassword* @return*/boolean updatesmalladmin(String sid, String sname, String spassword);/*** 改照片* @param sid* @param sqlImg* @return*/boolean updatesmalladminphoto(String sid, String sqlImg);
SmalladminServicelpml
/*** 修改普通管理员信息* @param sid* @param sname* @param spassword* @return*/@Overridepublic boolean updatesmalladmin(String sid, String sname, String spassword) {try {int countsmalladminname=smalladminMapper.countsmalladminname(sid,sname);//判断登录名是否重复if(countsmalladminname>0){throw new RuntimeException("登录名重复");}} catch (RuntimeException e) {return false;}smalladminMapper.updatesmalladmin(sid,sname,spassword);return true;}/*** 修改头像* @param sid* @param sqlImg* @return*/@Overridepublic boolean updatesmalladminphoto(String sid,  String sqlImg) {return smalladminMapper.updatesmalladminphoto(sid,sqlImg);}
SmalladminMapper
/*** 修改头像* @param sid* @param sqlImg* @return*/boolean updatesmalladminphoto(@Param("sid")String sid,@Param("sqlImg") String sqlImg);/*** 检查登录名是否重复* @param sid* @param sname* @return*/int countsmalladminname(@Param("sid")String sid,@Param("sname") String sname);/*** 修改普通管理员信息* @param sid* @param sname* @param spassword*/void updatesmalladmin(@Param("sid") String sid,@Param("sname") String sname,@Param("spassword") String spassword);
SmalladminMapper.xml
  <update id="updatesmalladminphoto">update smalladminset sphoto=#{sqlImg}where sid=#{sid}</update><select id="countsmalladminname" resultType="java.lang.Integer">select count(*)from smalladminwhere sname=#{sname} and sid!=#{sid}</select><update id="updatesmalladmin">update smalladminset sname=#{sname},spassword=#{spassword}where sid=#{sid}</update>

测试:

登录名重复

密码不一样

必填项为空

修改成功

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

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

相关文章

vue3+ant design vue + Sortable实现多级表格列拖动

1、最近遇到个需求&#xff0c;需使用vue3ant design vue Sortable实现多级表格的表头允许用户拖拽移动。即当用户拖拽一级表头时&#xff0c;其对应的子级表头及数据应同步移动&#xff0c;并且只允许一级非固定表头允许拖拽。 2、代码 <a-table:data-source"rowDat…

第五十四篇 AI与数据分析

一、AI数据分析就像做菜 想象你在厨房做一道新菜&#xff0c;AI数据分析的流程其实非常相似&#xff1a; 买菜&#xff08;获取数据&#xff09; 去市场挑选新鲜蔬菜 从Excel/数据库获取数据例&#xff1a;pd.read_csv(超市销售表.csv) 洗菜切菜&#xff08;清洗数据&#x…

差分OPA verilogaA 模型

做电路设计&#xff0c;需要提前用理想模型如VerilogA模型做验证。这里分享一个由ahdlib库里单端opamp改造而来的差分opamp。参考何乐年的《模拟集成电路设计与仿真》10.4节423页&#xff1b; 描述的小信号模型如上。 VerilogA 用到了SRI/C&#xff0c;GBWgm/C,gaingm*r1等概念…

Solidity语言基础:区块链智能合约开发入门指南

一、Solidity概述 Solidity是以太坊生态系统中最重要的智能合约编程语言&#xff0c;由Gavin Wood于2014年提出。作为面向合约的高级语言&#xff0c;它结合了JavaScript、Python和C的语法特点&#xff0c;专为在以太坊虚拟机&#xff08;EVM&#xff09;上运行而设计。 核心…

开启智能Kubernetes管理新时代:kubectl-ai让操作更简单!

在如今的科技世界中,Kubernetes 已经成为容器编排领域的标杆,几乎所有现代应用的基础设施都离不开它。然而,面对复杂的集群管理和日常运维,许多开发者常常感到无所适从。今天,我们将为大家介绍一款结合了人工智能的强大工具——kubectl-ai。它不仅能帮助开发者更加顺畅地与…

2003-2020年高铁站开通时间数据

2003-2020年高铁站开通时间数据 1、时间&#xff1a;2003-2020年 2、来源&#xff1a;Chinese High-speed Rail and Airline Database&#xff0c;CRAD 3、指标&#xff1a;高铁站名称、开通时间、所在省份、所在城市、所属线路名称 4、说明&#xff1a; Hsrwsnm[高铁站名…

神经网络—感知器、多层感知器

文章目录 前言一、生物神经元与感知器的类比二、感知器1、简单感知器2、多层感知器&#xff08;1&#xff09;多层感知机结构 3、神经网络结构 总结1、感知器的局限性如何突破感知器的局限性&#xff1f; 2、感知器的应用 前言 感知器&#xff08;Perceptron&#xff09;是神经…

避免数据丢失:在存储测试数据之前,要做好Redis持久化

Redis提供两种持久化方法&#xff1a; 一、RDB&#xff08;Redis DataBase&#xff09;&#xff1a; 1、周期性保存内存快照到磁盘&#xff08;生成 dump.rdb 文件&#xff09;。 2、配置save 相关参数。 我本地的配置如下&#xff1a; &#xff08;1&#xff09;配置文件re…

Oracle EBS FORM快捷键与触发器的关系与使用

Oracle EBS FORM快捷键与触发器的引用 1、快捷键作用&#xff0c;可以看文档fmrweb.res 2、文件内容&#xff1a;标识了快捷键的作用 9 : 0 : “Tab” : 1 : “Next Field” 9 : 1 : “ShiftTab” : 2 : “Previous Field” 116 : 0 : “F5” : 3 : “Clear Field” 38 : 0 :…

Java 24:重构数字信任边界 —— 后量子时代的智能安全防御体系构建

引言 在量子计算阴影与 AI 驱动攻击交织的网络安全新纪元&#xff0c;Java 平台正经历着自诞生以来最深刻的安全架构革新。作为企业级应用的核心基础设施&#xff0c;Java 24 不仅延续了 “一次编写&#xff0c;处处运行” 的跨平台基因&#xff0c;更以后量子密码学引擎、动态…

【故障定位系列】容器CPU问题引起的故障如何快速排查

原文地址&#xff1a;https://mp.weixin.qq.com/s/0VlIjbeEdPZUbLD389disA 当生产环境中的容器CPU出现异常时&#xff0c;可能会引发上层业务出现一系列问题&#xff0c;比如业务请求缓慢、网页卡顿甚至崩溃等&#xff0c;如果没有一个有效的故障定位方法&#xff0c;运维人员很…

DeepSeek 智能客服应用指南:构建、策略与成效升级

目录 一、引言二、DeepSeek 与智能客服的相遇2.1 DeepSeek 的技术亮点2.2 智能客服&#xff1a;企业不可或缺的 “数字助手”2.3 DeepSeek 如何适配智能客服需求 三、基于 DeepSeek 搭建智能客服系统3.1 需求分析3.2 技术选型3.3 系统架构设计3.4 搭建步骤实操 四、基于 DeepSe…

JVM运行时数据区域(Run-Time Data Areas)的解析

# JVM运行时数据区域(Run-Time Data Areas)的解析 欢迎来到我的博客&#xff1a;TWind的博客 我的CSDN:&#xff1a;Thanwind-CSDN博客 我的掘金&#xff1a;Thanwinde 的个人主页 本文参考于&#xff1a;深入理解Java虚拟机&#xff1a;JVM高级特性与最佳实践 本文的JVM均…

【特别版】Kubernetes集群安装(1master,2node)

Kubernetes集群安装 虚拟机准备 按照三台虚拟机标准&#xff0c;一台控制节点两台工作节点 主机名ip配置要求master-k8s192.168.242.102GB或更多RAM&#xff0c;2个CPU或更多CPU&#xff0c;硬盘30GB或更多node01-k8s192.168.242.112GB或更多RAM&#xff0c;2个CPU或更多CPU…

Excel点击单元格内容消失

Excel点击单元格内容消失 前言一、原因说明二、解决方案1.菜单栏中找到“审阅”&#xff0c;选择“撤销工作表保护”2.输入密码3.解除成功 前言 Excel想要编辑单元格内容时&#xff0c;无论是单击还是双击单元格内容都莫名其妙的消失了 一、原因说明 单击或者双击Excel中单元…

最优化方法Python计算:有约束优化应用——线性Lasso回归预测器

实际应用中&#xff0c;特征维度 n n n通常远大于样本容量 m m m&#xff08; n ≪ m n\ll m n≪m&#xff09;&#xff0c;这种高维小样本场景下特征数据可能含有对标签数据 y i y_i yi​的取值不必要的成分&#xff0c;甚至是噪声。此时&#xff0c;我们希望回归模型中的优化…

如何为APP应用程序选择合适的服务器

搭建一个成功的APP应用程序&#xff0c;服务器选择是至关重要的决策之一。合适的服务器不仅能确保应用流畅运行&#xff0c;还能节省成本并保障安全性。本文将为您详细解析如何为APP选择最佳服务器方案。 一、了解您的APP需求 在选择服务器前&#xff0c;首先需要明确您的应用…

k8s(11) — 探针和钩子

钩子和探针的区别&#xff1a; 在 Kubernetes&#xff08;k8s&#xff09;中&#xff0c;钩子&#xff08;Hooks&#xff09;和探针&#xff08;Probes&#xff09;是保障应用稳定运行的重要机制&#xff0c;不过它们的用途和工作方式存在差异&#xff0c;以下为你详细介绍&…

Kafka消息队列之 【消费者分组】 详解

消费者分组(Consumer Group)是 Kafka 提供的一种强大的消息消费机制,它允许多个消费者协同工作,共同消费一个或多个主题的消息,从而实现高吞吐量、可扩展性和容错性。 基本概念 消费者分组:一组消费者实例的集合,这些消费者实例共同订阅一个或多个主题,并通过分组来协调…

什么是Blender?怎么获取下载Blender格式文件模型

glbxz.com glbxz.com 官方可以下载Blender格式文件模型 BlenderBlender 是一个免费的开源程序&#xff0c;用于建模和动画&#xff0c;最初由一家名为 Neo Geo 的动画工作室作为内部应用程序开发&#xff0c;后来作为自己的程序发布。这是一个称职的程序&#xff0c;近年来由于…