重写HttpServlet的doGet、doPost方法时为什么要把它们的访问权限设为public?
看一本Java Web入门书时,其中提到HttpServlet的doGet方法是protected的,我们重写doGet方法时,为了使其能被Servlet容器访问,应该把访问权限设为public,然后我看网上的例子也全是把doGet写成public。Servlet容器为什么会直接访问doGet方法?HttpServlet的原理不是容器调用其service()方法,其service()根据实际的请求方法来调用doGet或者doPost的么。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
你见过哪个开源项目写
doGet
或doPost
是用public
的?至少我没见过。作用范围要尽量小(能用
private
的就不要用protected
,能用protected
的就不要用public
),这是编码中需要遵循的一个原则。先访问service方法,再通过service方法来判断使用doget或者dopost方法,但是我们自己写的servlet是继承了HttpServlet,重写了父类的doget和doPost,所以要用public才行。java设计这个可以提高权限的做法就是为了让子类可以自己去决定它的方法是否可以开放给调用者。子类用protected的话,servlet容器也是能够访问到的。一般重写的父类方法,访问权限都是>=父类的方法的。