當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript multer類代碼示例

本文整理匯總了TypeScript中multer的典型用法代碼示例。如果您正苦於以下問題:TypeScript multer類的具體用法?TypeScript multer怎麽用?TypeScript multer使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了multer類的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: getBodyParser

function getBodyParser(config: JsonBodyOptions | FileBodyOptions): RequestHandler {
    if (!config) return DEFAULT_JSON_PARSER;

    if (config.type === 'json') {
        return bodyParser.json(config);
    }
    else if (config.type == 'files') {
        const fConfig = config as FileBodyOptions;

        // validate config object
        if (typeof fConfig.field !== 'string') throw new TypeError(`'field' is undefined in file body options`);
        if (!fConfig.limits) throw new TypeError(`'limits' are undefined in file body options`);
        if (typeof fConfig.limits.size !== 'number' || typeof fConfig.limits.count !== 'number')
            throw new TypeError(`'limits' are invalid in file body options`);

        // build middleware
        const uploader = multer({
            storage: fConfig.storage || multer.memoryStorage(),
            limits: {
                files   : fConfig.limits.count,
                fileSize: fConfig.limits.size
            }
        }).array(fConfig.field);

        return function(request, response, next) {
            uploader(request, response, function (error) {
                if (error) {
                    const code: string = (error as any).code;
                    if (typeof code === 'string' && code.startsWith('LIMIT')) {
                        error = new Exception({ message: 'Upload failed', cause: error, status: HttpStatusCode.InvalidInputs });
                    }
                }
                next(error);
            });
        };
    }
    else if (config.type === 'multipart') {
        const bConfig = config as MultipartBodyOptions;

        const uploader = multer({
            storage : bConfig.storage || multer.memoryStorage(),
            limits  : bConfig.limits
        }).any();

        return function(request, response, next) {
            uploader(request, response, function (error) {
                if (error) {
                    const code: string = (error as any).code;
                    if (typeof code === 'string' && code.startsWith('LIMIT')) {
                        error = new Exception({ message: 'Request failed', cause: error, status: HttpStatusCode.InvalidInputs });
                    }
                }
                next(error);
            });
        };
    }
    else {
        throw new TypeError(`Body type '${config.type}' is not supported`);
    }
}
開發者ID:herculesinc,項目名稱:nova-server,代碼行數:60,代碼來源:RouteController.ts

示例2: multer

endpoints.forEach(endpoint =>
	endpoint.withFile ?
		app.post('/' + endpoint.name,
			endpoint.withFile ? multer({ dest: 'uploads/' }).single('file') : null,
			require('./api-handler').default.bind(null, endpoint)) :
		app.post('/' + endpoint.name,
			require('./api-handler').default.bind(null, endpoint))
開發者ID:syuilo,項目名稱:misskey-core,代碼行數:7,代碼來源:server.ts

示例3: start

  start() {
    let app: express.Express = express();
    app.use('/', express.static('public'));
    var upload: multer.Instance = multer(); // for parsing multipart/form-data

    //Server Middlewares configuration part
    app.use(allowCrossDomain);
    app.use(cookieParser()); // read cookies (needed for auth)
    app.use(bodyParser.json()); // for parsing application/json
    app.use(bodyParser.urlencoded({ extended: true })); // for parsing application/x-www-form-urlencoded
    app.use(expressSession({secret: 'swcmi'}));

    

    //To use passport 
    app.use(passport.initialize());
    app.use(passport.session()); // persistent login sessions

    //start router
    this.apiRouter.init(app);


    //port
    app.listen(10000, function () {
      console.log('SuWon church API Server listening on port 10000!')
    });

  }
開發者ID:jcdby,項目名稱:SuwonCMIAPIServer,代碼行數:28,代碼來源:server.ts

示例4: registerParsers

 private registerParsers() {
     // configure app to use bodyParser()
     // this will let us get the data from a POST
     this.app.use(bodyParser.urlencoded({ extended: true }));  // for parsing application/x-www-form-urlencoded
     this.app.use(bodyParser.json()); // for parsing application/json
     this.app.use(multer().any()); // for parsing multipart/form-data
 }
開發者ID:bap-node-microframework,項目名稱:node-microframework,代碼行數:7,代碼來源:application.ts

示例5: createReqFiles

function createReqFiles (
  fieldNames: string[],
  mimeTypes: { [ id: string ]: string },
  destinations: { [ fieldName: string ]: string }
) {
  const storage = multer.diskStorage({
    destination: (req, file, cb) => {
      cb(null, destinations[file.fieldname])
    },

    filename: async (req, file, cb) => {
      const extension = mimeTypes[file.mimetype]
      let randomString = ''

      try {
        randomString = await generateRandomString(16)
      } catch (err) {
        logger.error('Cannot generate random string for file name.', err)
        randomString = 'fake-random-string'
      }

      cb(null, randomString + extension)
    }
  })

  const fields = []
  for (const fieldName of fieldNames) {
    fields.push({
      name: fieldName,
      maxCount: 1
    })
  }

  return multer({ storage }).fields(fields)
}
開發者ID:quoidautre,項目名稱:PeerTube,代碼行數:35,代碼來源:utils.ts

示例6: describe

describe("Laod simple service rest", function() {

  let app = express();
  app.use(bodyParser.urlencoded({extended : false}));
  app.use(multer().array());  
  ServiceLoader.loadService(app, new serviceTest());

  it("should return a get", function(done) {

    request(app)
    .get("/one/1")
    .expect('{"id":"1","method":"get"}', done);
  });

  it("should return a post", function(done) {

    request(app)
    .post("/one")
    .field("id", 11)
    .expect('{"id":"11","method":"post"}', done);
  });

  it("should return a delete", function(done) {

    request(app)
    .delete("/one/2")
    .expect('{"id":"2","method":"delete"}', done);
  });

  it("should return a put", function(done) {

    request(app)
    .put("/one/3")
    .expect('{"id":"3","method":"put"}', done);
  });

  it("should return a patch", function(done) {

    request(app)
    .patch("/one/4")
    .expect('{"id":"4","method":"patch"}', done);
  });
});
開發者ID:lynchmaniac,項目名稱:threerest,代碼行數:43,代碼來源:service-load.ts

示例7: multer

/// <reference path="tsd.d.ts" />

import * as express from 'express'
import * as multer from 'multer'
import * as path from 'path';
import * as fs from 'fs';
import * as db from 'db';
import * as bodyParser from 'body-parser'
import {config} from 'config';
import {api as dapi} from 'discourse'
var upload = multer({ dest: config.uploadPath })

var app = express()
app.use(bodyParser.urlencoded({ extended: false }))
app.use(express.static('public'));


app.post('/postImg', upload.single('img'), function (req, res, next) {
    var tmpFile = path.join(__dirname, req.file.path);
    fs.rename(tmpFile, tmpFile + '.jpg', function () {
        res.json({ url: config.webAccessUploadURI + req.file.filename + '.jpg' });
    })
})

app.post('/post', function (req, res, next) {
    console.log(req.body);
    var doc = req.body;
    db.posts.loadDatabase();

    db.posts.insert(doc, function (err, newDoc) {   // Callback is optional
        if (err) {
開發者ID:sanwu,項目名稱:blog,代碼行數:31,代碼來源:server.ts

示例8: multer

                  not_submitted: responses[1]
                });
              });
            });
        });
    });
});

const upload = multer({
  limits: {
    fileSize: 1000000
  },
  storage: multerS3({
    acl: "public-read",
    bucket: "famjam",
    contentType: (req, file, cb) => {
      cb(null, "image/jpeg");
    },
    key: (req, file, cb) => {
      cb(null, uuid.v4());
    },
    s3: s3
  })
});

api.post("/topics/:id", authorizeToken, upload.single("photo"), (req, res) => {
  new Image({
    _creator: (req.authenticatedUser as IUser)._id,
    _topic: req.params["id"],
    description: req.body["description"],
    url: (req.file as any).location
  }).save((err, image: IImage) => {
開發者ID:rcchen,項目名稱:famjam,代碼行數:32,代碼來源:api.ts

示例9: express

import * as express from 'express'
import * as bodyParser from 'body-parser'
import * as multer from 'multer'
import * as path from 'path'
import route from '../route'
import reqRoute from './reqRoute'

const port: number = 8989

const app: any = express()
const upload: any = multer()

const server = app.listen(port, ():void=> {
  console.log(`http://localhost:${port}`)
})

const filePath = (fileName: string): string => {
  return path.join(__dirname + '/../data/' + fileName)
}

app.use(bodyParser.json({ limit: '50mb' }))
app.use(bodyParser.urlencoded({ extended: true }))
app.use(express.static('./dist'))

app.get('*', async (req: any,res: any) => {
  let data: any = await route(req)
  if( data.type === 'data'){
    res.send(data.data)
  } else {
    res.sendFile(filePath(await reqRoute(req.path)))
    // res.sendFile(filePath(data))
開發者ID:jfengsky,項目名稱:cquick,代碼行數:31,代碼來源:index.ts

示例10: multer

// MONGO CONFIG
const MongoClient = mongodb.MongoClient;
const ObjectId = mongodb.ObjectID;
const dbUrl = (config.dbUser && config.dbPwd) ? ('mongodb://' + config.dbUser + ':' + config.dbPwd + '@' + config.dbUrl) : ('mongodb://' + config.dbUrl);

// BCRYPT CONFIG
const saltRounds:number = 8;

// MULTER CONFIG
// AVATARS
const avtrUpload = multer({
  storage: multer.diskStorage({
    destination: (req, file, cb) => {
      cb(null, config.avtrPath)
    },
    filename: (req, file, cb) => {
      let ext = path.extname(file.originalname);
      cb(null, `${Math.random().toString(36).substring(7)}${ext}`);
    }
  })
});
// IMAGES
const imgUpload = multer({
  storage: multer.diskStorage({
    destination: (req, file, cb) => {
      cb(null, config.imgPath)
    },
    filename: (req, file, cb) => {
      let ext = path.extname(file.originalname);
      cb(null, `${Math.random().toString(36).substring(7)}${ext}`);
    }
開發者ID:Qcza,項目名稱:mean-ng2-scaffold,代碼行數:31,代碼來源:server.ts


注:本文中的multer類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。