zoukankan      html  css  js  c++  java
  • 工具和软件安装及学习资料

    一、Linux安装mysql(5.7.30)步骤及问题

    (1)Linux安装mysql步骤:https://blog.csdn.net/weixin_38003389/article/details/90696337

    (2)mysql启动问题:https://blog.csdn.net/weixin_33801856/article/details/93807230

    (3)securecrt连不上Linux的mysql:https://blog.csdn.net/fenglele_fans/article/details/81276667

    二、windows安装mysql

            mysql安装步骤:https://blog.csdn.net/qq_37350706/article/details/81707862

    三、虚拟机

    (1)centos7镜像下载:

             链接:https://pan.baidu.com/s/1ZMKybtvIBZS7zgNFiFPlhg 提取码:t400
             链接:https://pan.baidu.com/s/1eT1KqJ4 密码:lqgv

    (2)虚拟机安装centos7步骤:https://www.cnblogs.com/wcwen1990/p/7630545.html

             在安装的时候有software selection,选择server with gui可以设置图形界面

    (3)centos7安装图形界面:https://www.cnblogs.com/handongxue/p/9549047.html

    (4)centos7固定ip:https://www.cnblogs.com/itbsl/p/10219891.html

    四、centos安装docker

    (1)docker安装步骤:https://blog.csdn.net/li1325169021/article/details/90780627

    (2)获取阿里云镜像加速器:https://blog.csdn.net/li1325169021/article/details/90770119

             阿里云加速器地址:https://rmaycjhw.mirror.aliyuncs.com

    (3)启动docker:systemctl start docker

    (4)docker部署项目示例:https://blog.csdn.net/yangzailehehe/article/details/99625399

    (5)docker操作:

             开启docker:systemctl start docker
             删除docker镜像:docker rmi 镜像id
             删除docker容器:docker rm 容器id
             查看当前正在运行的容器:docker ps
             查看已退出的容器:docker ps -a
             查看所有镜像:docker images
             启动终止容器:docker start 容器id
             centos7使用firewall而不是iptables

    (6)老男孩docker视频:https://pan.baidu.com/s/1xl8f3NQ4sUfAfGqH3FVHDQ  密码: vit6

    五、SecureCRT和SecureFX

            安装步骤:https://blog.csdn.net/qq_27721169/article/details/81127746

    六、idea配置vue

    (1)node.js安装:https://blog.csdn.net/qq_39470733/article/details/80496404

    (2)IDEA配置npm启动:https://blog.csdn.net/jomexiaotao/article/details/80533548

    (3)将npm显示在左侧栏中:https://zhidao.baidu.com/question/693258700757305604.html

    七、vue执行流程

    (1)vue的执行流程:

             https://blog.csdn.net/YuDBL/article/details/85117202
             https://blog.csdn.net/YuDBL/article/details/85121184

    (2)vue中index.html、main.js、App.vue、index.js之前的关系以及加载过程:

             https://blog.csdn.net/qq_34182808/article/details/86690193

    八、git使用

    (1)git安装步骤:https://www.cnblogs.com/xueweisuoyong/p/11914045.html

             git安装与使用:https://blog.csdn.net/wawawawawawaa/article/details/81172452

    (2)码云仓库地址:https://gitee.com/xielili1/springcloudservice.git

    (3)git上传文件:https://my.oschina.net/u/4322747/blog/3243174/print

    (4)上传文件问题解决:     

             https://blog.csdn.net/qq_34908844/article/details/79039709
             https://blog.csdn.net/u014596302/article/details/86610078

    九、文件导入导出

    (1)excel数据导入导出mysql参考:

             https://blog.csdn.net/guanmao4322/article/details/82814721
             https://www.cnblogs.com/kyliechen/p/10732760.html
             ssm框架:https://blog.csdn.net/dirkwlk/article/details/81909663
             GitHub上:https://github.com/lihuibohemeng/170807_JavaPOISSM

    (2)excel导入导出mysql功能总结:

             最终参考:https://blog.csdn.net/dirkwlk/article/details/81909663
             代码下载:https://download.csdn.net/download/dirkwlk/10617815

    (3)excel模板导出参考:

             https://www.cnblogs.com/itmyhome/p/4131416.html
             https://blog.csdn.net/every__day/article/details/79006930

             excel模板导出总结:

    供给能力监测页面数据导出示例:
    
    导入依赖
    <dependency>
        <groupId>net.sf.jxls</groupId>
        <artifactId>jxls-core</artifactId>
        <version>1.0.5</version>
    </dependency>
    
    前台页面:
     function batchExportBtn(flag) {
        if(flag=="Y"){
            window.location="${ctx}/ui-portal/companymonitor/batchExportBtn?materialIds="+materialIds+"&sortName="+sortNameTmp+"&sortType="+sortTypeTmp+"&dataDate=" + dataDate;
        }else{
            swal("请联系管理员授权!");
        }
     }
    
    
    后台代码:
    //批量导出
    @ResponseBody
    @RequestMapping(value = "batchExportBtn", method = {RequestMethod.GET, RequestMethod.POST})
    public void batchExportBtn(@RequestParam(name = "materialIds") String materialIds,
                               @RequestParam(name = "provinceId", required = false) String provinceId,
                               @RequestParam(name = "sortName", required = false) String sortName,
                               @RequestParam(name = "sortType", required = false) String sortType,
                               @RequestParam(name = "dataDate", required = false) String dataDate) {
        logger.debug("materialIds[{}]", materialIds);
        logger.debug("sortName[{}]", sortName);
        logger.debug("sortType[{}]", sortType);
    
        JSONObject result = null;
        String resultCode = "0";
        String resultInfo = "success";
    
        Map<String, Object> param = new HashMap<String, Object>();
    
        List<JSONObject> provinceDataInfoList = new ArrayList<JSONObject>();
        MaterialInfoMVO materialInfoMVO = new MaterialInfoMVO();
        try {
            if (materialIds == null || materialIds.length() == 0) {
                throw new AppException("12", "materialIds is null");
            }
    
            param.put("materialIds", materialIds);
    
            param.put("provinceId", provinceId);
            param.put("sortName", sortName);
            param.put("sortType", sortType);
            param.put("dataDate", dataDate);
    
            result = companyMonitorDelegate.getProvinceDataInfo(param);
            provinceDataInfoList = result.getJSONArray("provinceDataInfoList");
    
    
            materialInfoMVO.setMaterialId(materialIds);
            materialInfoMVO = materialInfoDelegate.queryBean(materialInfoMVO);
    
            result.put("materialUnit", materialInfoMVO.getMaterialUnit());
    
    
        } catch (AppException e) {
            resultCode = e.getErrId();
            resultInfo = e.getErrMsg();
        } catch (SysException e) {
            e.printStackTrace();
            resultCode = "31";
            resultInfo = e.getMessage();
        } catch (Exception e) {
            e.printStackTrace();
            resultCode = "-1";
            resultInfo = e.getMessage();
        }
    
        Map<String, Object> map = new HashMap<String, Object>();
        map.put("title", materialInfoMVO.getMaterialName());
        map.put("list", provinceDataInfoList);
        map.put("materialUnit", materialInfoMVO.getMaterialUnit());
        String tmp = CompanyMonitorController.class.getResource("/").getPath();
        System.out.println(tmp);
    
        tmp = tmp.substring(0, tmp.indexOf("WEB-INF")) + "WEB-INF/xlsTemplate/";
        System.out.println(tmp);
        String templateFilePath = tmp + "ggnljcResult.xls";
        String timeM = String.valueOf(System.currentTimeMillis());
        try {
            templateFilePath = URLDecoder.decode(templateFilePath, "utf-8");
            // 生成文件流
            Workbook workbook = new XLSTransformer().transformXLS(new FileInputStream(templateFilePath), map);
    
            // 准备下载
            ExportUtil.doDownLoad(workbook, "供给能力监测"+dataDate+".xls", response);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    
    
    
    工具类ExportUtil
    
    package com.ui.portal.util;
    import org.apache.poi.hssf.usermodel.*;
    import org.apache.poi.ss.usermodel.Workbook;
    import javax.servlet.http.HttpServletResponse;
    import java.io.IOException;
    import java.io.OutputStream;
    import java.net.URLEncoder;
    
    /**
     * @author luffy--
     * @data 2018/11/13 14:38
     */
    public class ExportUtil {
        /**
         * 导出Excel
         * @param sheetName sheet名称
         * @param title 标题
         * @param values 内容
         * @param wb HSSFWorkbook对象
         * @return
         */
        public static HSSFWorkbook getHSSFWorkbook(String sheetName, String []title, String [][]values, HSSFWorkbook wb){
            // 第一步,创建一个HSSFWorkbook,对应一个Excel文件
            if(wb == null){
                wb = new HSSFWorkbook();
            }
            //在workbook中添加一个sheet,对应Excel文件中的sheet
            HSSFSheet sheet = wb.createSheet(sheetName);
            //在sheet中添加表头第0行
            HSSFRow row = sheet.createRow(0);
            // 创建单元格,并设置值表头 设置表头居中
            HSSFCellStyle style = wb.createCellStyle();
            style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 创建一个居中格式
            style.setFillForegroundColor((short) 13);//设置背景颜色
            style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
            //声明列对象
            HSSFCell cell = null;
            //创建标题
            for(int i=0;i<title.length;i++){
                cell = row.createCell(i);
                cell.setCellValue(title[i]);
                cell.setCellStyle(style);
            }
            //创建内容
            for(int i=0;i<values.length;i++){
                row = sheet.createRow(i + 1);
                for(int j=0;j<values[i].length;j++){
                    //将内容按顺序赋给对应的列对象
                    row.createCell(j).setCellValue(values[i][j]);
                }
            }
            return wb;
        }
    
    
        public static void doDownLoad(Workbook workbook, String name, HttpServletResponse response) {
            OutputStream fos = null;
            try {
                response.reset();
                response.setHeader("Content-disposition", "attachment;success=true;filename =" + URLEncoder.encode(name, "utf-8"));
                fos = response.getOutputStream();
                workbook.write(fos);
                fos.flush();
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                if (fos != null) {
                    try {
                        fos.close();
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                }
            }
        }
    }
    
    
    
    excel模板中使用jxls循环获取数据
    View Code

    (3)文件上传参考:       

             https://www.jb51.net/article/113068.htm
             https://www.cnblogs.com/flypig666/p/11745249.html

             自己文件上传代码:

    前端页面:
     <div style="margin-top: 10px;">
        <input type="file" id="upload" name="upload" value="" style="float: left" />
        <button onclick="uploadFile()" style="float: left">上传</button>
    </div>
    
    
    //文件上传函数
    function uploadFile(){
        var file = $("#upload").val();
        file = file.substring(file.lastIndexOf('.'), file.length);
        console.log(file,"file")
        if (file == '') {
            alert("上传文件不能为空!");
        }else{
            var formData = new FormData();
            var name = $("#upload").val();
            formData.append("file", $("#upload")[0].files[0]);
            formData.append("name", name);
            $.ajax({
                url : "${ctx}/companyinfo/evaluatefeedbackinfo/fileUpload",
                type : "POST",
                async : false,
                data : formData,
                processData : false,
                contentType : false,
                beforeSend : function() {
                    console.log("正在进行,请稍候");
                },
                success : function(e) {
                    if (e == "01") {
                        alert("恭喜您,上传成功!", function () {
                        }, {type: 'success', confirmButtonText: 'OK'});
                    } else {
                        alert("上传失败");
                    }
                }
            });
    
        }
    }
    
    
    
    
    后台代码:
     /**
      * 文件上传
      */
    @RequestMapping(value = "/fileUpload",method = RequestMethod.POST)
    @ResponseBody
    public String fileUpload(@RequestParam("file") MultipartFile file, HttpServletRequest request) throws Exception {
        CacheManager cacheManager = CacheManager.getInstance();
        String flag = "";// 上传标志
        if (!file.isEmpty()) {
            try {
                //获取文件名,防止中文文件名乱码
                String filename = new String(file.getOriginalFilename().getBytes("ISO-8859-1"), "UTF-8");
                //上传文件路径
                //String tmp = EvaluateFeedBackInfoController.class.getResource("/").getPath();
                //String path = tmp.substring(0, tmp.indexOf("WEB-INF")) + "WEB-INF/uploadfile/";
    
                String path=(String) cacheManager.get("table.cache.idvalue.sysconfig", "900035");
                //创建文件实例
                File filePath = new File(path,filename);
                //写入文件
                file.transferTo(filePath);
                flag = "01";
            } catch (Exception e) {
                flag = "03";// 上传出错
                e.printStackTrace();
            }
        }
        return flag;
    }
    
    
    
    
    总结:文件上传路径写对,请求类型不要错
    
    为了防止文件名是中文乱码,需要处理一下
    
    得到文件上传路径和文件名,创建文件实例,参数传入路径和文件名称
    
    然后调用多文件的transferTo方法进行文件上传
    View Code

    (4)文件下载参考:

             https://blog.csdn.net/Cheng_May/article/details/78600833
             https://blog.csdn.net/bingocbj/article/details/72858906
             https://blog.csdn.net/wwd0501/article/details/49890881/

             自己文件下载代码:

    前端页面:
    <a value = "+evaluateFeedBackInfoMVOS[i].backFileUrl+" onclick="downFile(this)">查看附件</a>
    
    function downFile(data) {
        //根据value属性获取到value的值
        filename = $(data).attr("value");
        window.location.href = "${ctx}/ibdpnb/evaluatefeedbackinfo/download?filename="+filename;
    }
    
    
    后台代码:
    /**
     * 文件下载
     */
    @RequestMapping(value = "/download",method = RequestMethod.GET)
    public void download(HttpServletResponse response) throws IOException  {
        CacheManager cacheManager = CacheManager.getInstance();
        response.setCharacterEncoding("UTF-8");
        response.setContentType("text/html;charset=utf-8");
        //获得请求文件名
        String filename = request.getParameter("filename");
        //读取目标文件,通过response将目标文件写到客户端
        //获取目标文件的绝对路径
        String path=(String) cacheManager.get("table.cache.idvalue.sysconfig", "900035");
        String fullFileName = path +"/"+ filename;
        //处理文件名称为中文下载文件名异常的情况
        //filename = new String(filename.getBytes(), "ISO-8859-1");
        filename = URLEncoder.encode(filename,"UTF-8");
        //通知浏览器以下载的方式打开
        response.addHeader("Content-type", "appllication/octet-stream");
        response.addHeader("Content-Disposition", "attachment;filename="+filename);
    
        //读取文件
        InputStream in = new FileInputStream(fullFileName);
        OutputStream out = response.getOutputStream();
        //写文件
        int b;
        while((b=in.read())!= -1)
        {
            out.write(b);
        }
        in.close();
        out.close();
    }
    
    
    
    总结:文件下载使用路径跳转的形式,请求类型为GET请求
    
    得到文件名以及文件下载路径,拼接成完整的文件路径,注意"/"不要缺少
    
    由于文件名为中文名下载的文件会有异常,需要对文件名称处理一下,两种方式都可以
    
    设置浏览器以下载方式打开
    
    定义文件输入流和输出流对文件进行读取和写入,最后关闭流
    View Code

    十、ajax同步与异步

            ajax优缺点与使用:https://www.cnblogs.com/yangguoe/p/8461932.html

    十一、sitemesh的简介

            sitemesh简介:https://www.cnblogs.com/lexiaofei/p/7044497.html

    十二、jstree简介

            jstree详细教程:https://www.iteye.com/blog/yiding-123-2345329
            jstree:https://blog.csdn.net/weixin_39752671/article/details/89972828
            jstree文档:https://blog.csdn.net/qq_36640744/article/details/80093313

    十三、linux安装rabbitmq、redis

            linux安装rabbitmq:https://www.cnblogs.com/fengyumeng/p/11133924.html
            linux安装redis:https://www.cnblogs.com/zuidongfeng/p/8032505.html

     十四、shiro实现登录认证与权限授权管理            

            shiro配置:https://www.cnblogs.com/sharpest/p/5867851.html
            shiro学习书籍:跟我学shiro教程
            shiro登录成功之后跳转url:https://blog.csdn.net/qq_38157516/article/details/80587789
            shiro源码研究之登录与登出:https://blog.csdn.net/lqzkcx3/article/details/78819536
            shiro源码研究之构建Subject实例:https://blog.csdn.net/lqzkcx3/article/details/78801403
            shiro的session和spring的session:https://www.cnblogs.com/onlymate/p/8391274.html

    十五、SpringCloud微服务学习资料

            4天从浅入深精通SpringCloud 微服务架构完整视频:http://yun.itheima.com/course/600.html?2003sxk
            配套资料:https://pan.baidu.com/s/1DFrV3m4mF8Y7-Rkgv98irw 提取码:xj0g

     十六、Python爬虫技术5天速成(2020全新合集)

       Python入门+数据可视化:https://www.bilibili.com/video/BV12E411A7ZQ?from=search&seid=12516173322672444643

       爬取的网站案例:豆瓣电影   https://movie.douban.com/top250

     十七、java虚拟机指令集

       java虚拟机:https://cloud.tencent.com/developer/article/1333540

    十八、powerdesigner安装

      powerdesigner安装:https://www.fujieace.com/software/powerdesigner.html

  • 相关阅读:
    使用RecyclerView打造Gallery
    Retrofit简介与使用方法(翻译)
    迷宫实现递归版本C++
    牛客笔试题
    牛客笔试题---求最长重复词长度之和
    C++句柄解析
    C++双向循环链表实现
    String C++完整实现。
    String写时拷贝实现
    顺序表操作补充(查找方法增加)
  • 原文地址:https://www.cnblogs.com/cxli99/p/12826751.html
Copyright © 2011-2022 走看看