通过Heroku部署后无法使用的应用程序
我正在尝试将我的应用程序部署到我认为正在工作的Heroku。在通过Localhost测试我的应用程序时,它可以正常工作,所有内容都在发布。但是,在部署并替换了我所有的URL到Heroku之后,数量不起作用:
- Giphy API不再起作用,
- 什么都不会发布(评论和喜欢工作,但帖子不工作),但
我尝试调试,但是什么都没有起作用。我要去哪里?请参阅下面的详细信息
应用程序: httpps://mitnickproject1-journal-app.netlify.app/ heroku:
” - 末端代码
const formEl = document.querySelector('form');
formEl.addEventListener('submit', postFormData)
let count=0;
async function postFormData(e) {
const current= new Date().toLocaleString()
const formData= new FormData(formEl) // console.log this to check what format this is in
const formDataSerialised=Object.fromEntries(formData) //console.log this to see what this does
const jsonObject = {...formDataSerialised, "dateTime": current, "comment": [], "EmojiCount": [0,0,0], "gifLink":gifLink, 'id': count}
console.log(JSON.stringify(jsonObject, null, 2))
try{
const options = { method: 'POST',
body: JSON.stringify(jsonObject),
headers: {
'Content-Type': 'application/json'
}
}
await fetch("https://journal-post-pl.herokuapp.com/test", options);
// const response = await fetch("https://journal-post-pl.herokuapp.com/test", {
// })
// const json = await response.json();
}catch(err){
console.error(err);
alert('There was an error')
}
}
后端代码
app.post('/test', (req, res) => {
formData.push(req.body)
console.log(formData)
writeToJson();
res.json({success: true})
})
任何帮助都将不胜感激
I'm trying to deploy my app to Heroku in which I believe is working. Whilst testing my app via localhost it works fine, everything is posting. However after deployment and replacing all my URLs to Heroku, number of things are not working:
- The GIPHY API no longer works
- Nothing would post (comments and likes work but not the posting)
I have tried debugging however nothing has worked. Where am I going wrong? Please see below for details
app: https://mitnickproject1-journal-app.netlify.app/
heroku: https://journal-post-pl.herokuapp.com/print
Front-end code
const formEl = document.querySelector('form');
formEl.addEventListener('submit', postFormData)
let count=0;
async function postFormData(e) {
const current= new Date().toLocaleString()
const formData= new FormData(formEl) // console.log this to check what format this is in
const formDataSerialised=Object.fromEntries(formData) //console.log this to see what this does
const jsonObject = {...formDataSerialised, "dateTime": current, "comment": [], "EmojiCount": [0,0,0], "gifLink":gifLink, 'id': count}
console.log(JSON.stringify(jsonObject, null, 2))
try{
const options = { method: 'POST',
body: JSON.stringify(jsonObject),
headers: {
'Content-Type': 'application/json'
}
}
await fetch("https://journal-post-pl.herokuapp.com/test", options);
// const response = await fetch("https://journal-post-pl.herokuapp.com/test", {
// })
// const json = await response.json();
}catch(err){
console.error(err);
alert('There was an error')
}
}
Back End Code
app.post('/test', (req, res) => {
formData.push(req.body)
console.log(formData)
writeToJson();
res.json({success: true})
})
Any help would be appreciated
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
我检查了您的代码,并在查看控制台时对其进行了测试。
您的GIPHY URL使用
HTTP
而不是https
。 HTTP适合开发,但是实时网站需要使用HTTP。只需将所有HTTP URL切换到https
即可。您的服务器未设置为接受外部来源(又称CORS)的任何请求。要解决此问题,只需将
app.use(cors())
添加到服务器文件。别忘了将
const cors = require('cors')
放在顶部。I checked out your code and tested it out while looking at the console.
Your GIPHY urls are using
http
instead ofhttps
. http is fine for development, but live site needs to use https. Just switch all your http urls tohttps
and that will work.Your server isn't set up to accept any requests from an outside source (AKA CORS). To fix this, just add
app.use(cors())
to your server file.Don't forget to put
const cors = require('cors')
at the top.