zoukankan      html  css  js  c++  java
  • Deno 文件上传

    Deno上传文件

    视频讲解 https://www.bilibili.com/video/BV1BT4y1E7Nh/?p=6

    我们一起来完成以下步骤:

    1. 沿用之前的工程代码
    2. 创建上传页面和响应的controller
    3. 添加上传文件功能
    4. 测试

    #controllers/controller.ts

    const { cwd } = Deno;
    
    class Controller {
        static async getData(ctx: any){
            //cwd获取当前工程目录 
            //注意 ' !== `
            ctx.render(`${cwd()}/views/index.ejs`,{
                title:"Testing",
                data:{name:"deepincoding"}
            }); 
        }
        static async uploadPage(ctx: any){
            ctx.render(`${cwd()}/views/upload-page.ejs`);
        }
    
        static async uploadAction(ctx: any){
            //我们这里不返回页面,而是返回上传文件的信息
            ctx.response.body = ctx.uploadedFiles;
        }
        
    }
    
    export default Controller;
    

    #routers/index.ts

    import { Router } from "https://deno.land/x/oak/mod.ts";
    import Controller from "../controllers/Controller.ts";
    import { upload } from "https://deno.land/x/upload_middleware_for_oak_framework/mod.ts";
    
    
    const router = new Router();
    
    router.get("/",Controller.getData);
    
    router.get("/uploadPage",Controller.uploadPage);
    
    router.post("/uploadAction", upload('uploads', ['jpg','png'], 20000000, 10000000, true, false, true),Controller.uploadAction);
    
    export default router;
    

    #views/upload-page.ejs

    <body>
    <form id="yourFormId" enctype="multipart/form-data" action="/uploadAction" method="post">
        <input type="file" name="file1" multiple><br>
        <input type="submit" value="Submit">
      </form>
    </body>  
    

    #main.ts

    
    import { Application } from "https://deno.land/x/oak/mod.ts"
    import {viewEngine,engineFactory,adapterFactory} from "https://deno.land/x/view_engine/mod.ts";
    import router from "./routers/index.ts";
    
    const ejsEngine = engineFactory.getEjsEngine();
    const oakAdapter = adapterFactory.getOakAdapter();
    
    const app = new Application();
    app.use(viewEngine(oakAdapter,ejsEngine));
    app.use(router.routes());
    app.use(router.allowedMethods());
    
    await app.listen({port: 8000 })
    
    

     

  • 相关阅读:
    安裝Node.js
    es match、match_phrase、query_string和term的区别
    ES系列十、ES常用查询API
    ElasticSearch 入门总结
    起立,老师好
    像哆啦A梦懂大雄一样懂客户,我们也会拥有百宝箱
    阿里云居然在偷偷发福利!
    别人家的公司又来了,这次竟然开起了演唱会
    听说国家博物馆收藏了一行代码 ???
    我还是那个我,为啥就被老板区别对待了呢?
  • 原文地址:https://www.cnblogs.com/JavaWeiBianCheng/p/13071086.html
Copyright © 2011-2022 走看看