会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132462个问题

老师我按照你的代码敲得出来一直是服务器报错500

servlet代码

package com.bjsxt.servlet;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.MultipartConfig;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;
import java.io.IOException;
import java.io.InputStream;
import java.io.PrintWriter;
import java.util.UUID;

@WebServlet("/fileupload.do")
@MultipartConfig
public class FileUploadServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        this.doPost(req, resp);
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        req.setCharacterEncoding("utf-8");
        String desc = req.getParameter("desc");
        Part part = req.getPart("file");
        /*//获取文件上传的字节流
        InputStream inputStream = part.getInputStream();*/
        //给文件改名
        String fileName = UUID.randomUUID().toString()+part.getSubmittedFileName().substring(part.getSubmittedFileName().lastIndexOf("."));
        //路径转换
        ServletContext servletContext = this.getServletContext();
        String realPath = servletContext.getRealPath("images/" + fileName);
        part.write(realPath);
        resp.setContentType("text/html;charset=utf-8");
        PrintWriter out = resp.getWriter();
        out.println("<!DOCTYPE HTML PUBLIC '-//W3C//DTD HTML 4.0 Transitional//EN'>");
        out.println("<HTML>");
        out.println("<HEAD><TITLE> ITBZ </TITLE></HEAD>");
        out.println("<BODY>");
        out.println("上传成功!"+desc);
        out.println("</BODY>");
        out.println("</HTML>");
        out.flush();
        out.close();
    }
}

hmtl代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<form action="fileupload.do" method="post" enctype="multipart/form-data">
    文件描述:<input type="text" name="desc"/>
    上传文件:<input type="file" name="file"/>
    <input type="submit" value="OK"/>
</form>
</body>
</html>

就这2个了吧,我敲出来就是服务器500.我看了好久,他总是先运行上一章initServlet的Servlet因为他每次都会输出三个value的值,我把这个代码全部注释掉了再试了一次,还是一样的500报错。

image.png

老师可以帮我看看吗

JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解(旧) 34336楼
Python 全系列/第一阶段:Python入门/Python入门(动画版) 34337楼

"""
新增功能
     左上角文字绘制;
     左上角输出敌方坦克数量6

"""
import pygame

SCREEN_WIDTH = 700
SCREEN_HEIGHT = 500
BG_COLOR = pygame.Color(0, 0, 0)
TEXT_COLOR = pygame.Color(255, 0, 0)


class MainGame():
    window = None

    def __init__(self):
        pass

    # 开始游戏
    def startGame(self):
        # 加载主窗口
        pygame.display.init()
        # 设置窗口的大小及显示
        MainGame.window = pygame.display.set_mode([SCREEN_HEIGHT, SCREEN_HEIGHT])
        # 设置窗口的标题
        pygame.display.set_caption("坦克大战1.03")
        while True:
            # 给窗口设置填充色
            MainGame.window.fill(BG_COLOR)
            # 获取事件
            self.getEvent()
            # 绘制文字的方法
            MainGame.window.blit(self.getTextSuface('敌方坦克剩余数量%d' % 6))
            pygame.display.update()

    # 结束游戏
    def endGame(self):
        print("谢谢使用,欢迎再来")
        exit()

    # 左上角文字绘制
    def getTextSuface(self):
        # 初始化字体模块
        pygame.font.init()
        # 查看所有字体名称
        print(pygame.font.get_fonts())
        # 获取字体font对象
        font = pygame.font.SysFont("georgia", 18)
        # 绘制文字信息
        textSurface = font.render(text, True, TEXT_COLOR)
        return textSurface

    # 获取事件
    def getEvent(self):
        # 获取所有事件
        eventList = pygame.event.get()
        # 遍历事件
        for event in eventList:
            # 判读按下的是关闭还是键盘
            # 如果安的是退出,
            if event.type == pygame.QUIT:
                self.endGame()
                # 如果是键盘的按下
                if event.type == pygame.KEYDOWN:
                    # 判断按下的是上,下,左,右
                    if event.key == pygame.K_LEFT:
                        print("按下左键,坦克向左移动")
                    elif event.key == pygame.K_RIGHT:
                        print("按下右键,坦克向右移动")
                    elif event.key == pygame.K_UP:
                        print("按上键,坦克向上动")
                    elif event.key == pygame.K_DOWN:
                        print("按下键,坦克向右下动")


class Tank():
    def __init__(self):
        pass

    # 移动
    def move(self):
        pass

    # 射击
    def shot(self):
        pass

    # 展示坦克的方法
    def display(self):
        pass


# 我方坦克
class MyTank(Tank):
    def __init__(self):
        pass


class EnemyTank(Tank):
    def __init__(self):
        pass


# 子弹类
class Bullet():
    def __init__(self):
        pass

    # 移动
    def move(self):
        pass

    # 展示子弹的方法
    def displayBullet(self):
        pass


class Wall():
    def __init__(self):
        pass

    # 展示墙壁的方法
    def displayWall(self):
        pass


class Explode():
    def __init__(self):
        pass

    # 展示爆炸效果的方法
    def displayExplode(self):
        pass


class Music():
    def __init__(self):
        pass

    # 播放音乐
    def play(self):
        pass


if __name__ == "__main__":
    MainGame().startGame()
    MainGame().getTextSuface()


Python 全系列/第二阶段:Python 深入与提高/游戏开发-坦克大战 34338楼
WEB前端全系列/第一阶段:HTML5+CSS3模块/响应式项目 34339楼
JAVA 全系列/第八阶段:SpringBoot与MybatisPlus/Swagger(旧) 34340楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/网络编程(旧) 34342楼
WEB前端全系列/第一阶段:HTML5+CSS3模块/表单 34344楼
JAVA 全系列/第六阶段:项目管理与SSM框架/Mybatis 34345楼
Python 全系列/第十九阶段:数据分析-数据管理/Pandas(旧) 34346楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/Lambda表达式(旧) 34347楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="jquery-1.8.3.js"></script>
    <style>
        *{padding: 0;margin: 0;}
        div{ width: 400px;border: 3px solid skyblue;margin: 100px auto;padding: 20px;}
        li{
            width: 100px;display: inline;
        }
        ul{text-align: center;list-style: none;}
button{width: 40%; background-color: aquamarine;height: 40px;line-height: 40px;text-align: center;margin: 5px auto;}
    </style> 
</head>
<body>
   <div class="con">
       <ul>
           <li class="hide">1</li>
           <li>2</li>
           <li>2</li> 
           <li>2</li>
           <li>2</li>
           <li>2</li>
           <li>2</li>
           <li>2</li>
           <li class="hide">1</li>
           <li>2</li>
           <li class="hide">1</li>
           <li class="hide">1</li>
           <li>2</li> 
           <li>2</li>
           <li>2</li>
           <li>2</li>
           <li>2</li>
           <li>2</li>
           <li>2</li> 
           <li>2</li>
           <li>2</li>
           <li>2</li>
           <li>2</li>
           <li>2</li><li>2</li> 
           <li>2</li>
           <li>2</li>
           <li>2</li>
           <li>2</li>
           <li>2</li>
       </ul>
       <button>显示2</button>
   </div>
   <script>
       $('button').toggle(function(){
           $('.hide').hide(200);
           $('button').html('显示1和2');

       },function(){
        $('.hide').show(200);
           $('button').html('显示2');
       })
   </script>
</body>
</html>

老师为什么隐藏后再显示的跟隐藏前显示的布局不一样

image.pngimage.pngimage.png

WEB前端全系列/第三阶段:jQuery编程模块/jQuery基础知识(旧) 34348楼
WEB前端全系列/第二阶段:JavaScript编程模块/JavaScript基础与变量 34349楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637