关于Servlet请求头数据的小问题

这个请求头数据的获取逻辑不是很懂,也不明白这里的遍历为什么是用**while**,有大佬能解释一下吗?

package com.cherry.requset;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.Enumeration;

@WebServlet("/RequestHander")
public class RequestHander extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

        //1.获取所有请求头名称
        Enumeration<String> headerNames = request.getHeaderNames();
        //2.遍历
        while (headerNames.hasMoreElements()){
            String name = headerNames.nextElement();
            //3.根据名称获取请求头得值
            String value = request.getHeader(name);
            System.out.println(name+"---"+value);
        }
    }
}

首先我们浏览器打开调试模式,然后输入baidu.com;可以看到 header 里存放了很多的值;
所以获取header里值,用循环是没有毛病的;
而这里为什么用while循环:
1、可能我不知道前台请求 header里都会传递什么值
2、使用hasMoreElements方法,有值则继续循环,无值则跳出循环
图片说明
图片说明

header里面可能存放了很多值阿(Host、User-Agent、Token等)