一些Http请求在本地工作,但在Heroku中不工作怎么修?

问题描述

我已经构建了一个MERN应用并部署到Heroku。在本地,一切正常,例如用户可以注册然后登录。但是,在Heroku上运行的应用让我注册但没有登录。POST请求/ login返回401未经授权。我的应用似乎只配置了HTTP请求,而不配置了HTTPS请求。这是我遇到的问题吗?我的应用程序还尝试从外部API加载资源,该资源也会失败,因为该资源未通过HTTPS提供。我不确定在这里分享什么代码,但这是我的 后端的

app.js

const express = require('express')
const app = express()
const cors = require('cors')
const mongoose = require('mongoose')
const config = require('./utils/config')
const morgan = require('morgan')

const middleware = require('./utils/middleware')
const habitRouter = require('./controllers/habit')
const usersRouter = require('./controllers/users')
const loginRouter = require('./controllers/login')

morgan.token('data',(req,res) => {
  JSON.stringify(req.body);
});

const loggerFormat = ':data ":method :url" :status :response-time';

app.use(morgan(loggerFormat));

mongoose
  .connect(process.env.MONGODB_URI,{
    useNewUrlParser: true,useUnifiedTopology: true,useCreateIndex: true,useFindAndModify: false
  })
  .then(() => {
    console.log('connected to MongoDB via url: ',config.MONGODB_URI);
  })
  .catch((error) => {
    console.log('error connecting to MongoDB',error.message);
  });

app.use(cors())
app.use(bodyParser.json())
app.use(middleware.tokenExtractor)

if (process.env.NODE_ENV === 'test') {
  const testingRouter = require('./controllers/testing')
  app.use('/api/testing',testingRouter)
}

if (process.env.NODE_ENV === 'production') {
  app.use(express.static('build'))
}

app.use('/api/habits',habitRouter)
app.use('/api/users',usersRouter)
app.use('/api/login',loginRouter)


module.exports = app

login.js

const jwt = require('jsonwebtoken')
const bcryptjs = require('bcryptjs')

const config = require('../utils/config')
const loginRouter = require('express').Router()
const User = require('../models/user')

loginRouter.post('/',async (request,response) => {

  try {
  const user = await User.findOne({ username: request.body.username }).populate('habits')
  console.log('user',user)
  const passwordCorrect = user === null 
    ? false
    : await bcryptjs.compare(request.body.password.toString(),user.passwordHash)

    if (!(user && passwordCorrect)) {
      return response.status(401).json({
        error: 'invalid username or password'
      })
    }

    const userForToken = {
      username: user.username,id: user._id
    }

    const token = jwt.sign(userForToken,config.SECRET)

    response.status(200).send({ token,username: user.username,habits: user.habits,id: user._id})
  } catch (exception) {
    console.log(exception)
    response.status(401).send({ error: exception.message })
  }
})

module.exports = loginRouter

如果是HTTP / HTTPS问题,如何为HTTPS配置它?谢谢。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...