整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

前端入门-html 表单

前面已经学习相关html大部分知识,基本上可以制作出简单的页面,但是这些页面都是静态的,一个网站如果要实现用户的互动交流,这时表单就起到关键的作用,表单的用途很多,它主要用来收集用户的相关信息,是网页具有交互的功能。例如,用户注册登录,留言等。

下面会详细介绍表单的使用方法,有以下内容:

  • 表单标签form的使用
  • 表单控件使用

表单标签 —— form

使用<form></form>标签来创建一个表单,在其之间就是各种表单控件,如,输入框,文本框,单选按钮,多选按钮,提交按钮等。

语法代码如下:

<form name="表单名称" action="表单处理程序的服务地址" method="提交表单时所用的HTTP方法">
  ...... 表单控件......
  </form>

1、action —— 处理程序

这里的 action 属性值表单提交的地址,就是表单收集好数据后要传递给远程服务的地址,其地址可以是绝对路径也可以是相对路径,或者其它形式,如发送电子邮件。

使用表单发送电子邮件:

<form action="mailto:xxx@126.com">
  ...... 表单控件......
  </form>

提交到后台程序地址:

<form action="action_page.php">
  ...... 表单控件......
  </form>

2、name —— 表单名称

表单名称,这一属性不是必需的,但是为了防止表单信息提交到后台处理程序时发生混乱,一般要设置一个名称,且在同一页面中最好是唯一的,不要和其它表单重复命名。

<form name="loginForm">
  ...... 表单控件......
  </form>

3、method —— 传送数据方法

method 属性用来定义处理程序使用那种方法来获取数据信息,常用的有 get 和 post (http 协议定义的方法)。

<form name="loginForm" action="get 或 post">
  ...... 表单控件......
  </form>

何时使用 GET?

GET 最适合少量数据或不是很重要数据的提交,浏览器会设定容量限制,默认如何没有设置method 属性,表单则会使用get 方法。

当您使用 GET 时,表单数据在页面地址栏中是可见的,会在表单提交的地址后面跟一个问号“?” ,问号后面是数据,以 名称1=值1&名称2=值2 形式发送到后台程序。

地址栏会看到如下:

action_page.php?firstname=Mickey&lastname=Mouse

关于 GET 的注意事项:

以名称/值对的形式将表单数据追加到 URL

永远不要使用 GET 发送敏感数据!(提交的表单数据在 URL 中可见!)

URL 的长度受到限制(2048 个字符)

对于用户希望将结果添加为书签的表单提交很有用

GET 适用于非安全数据,例如 Google 中的查询字符串

何时使用 POST?

使用post 表单数据和url(表单提交地址)是分开发送的,在页面地址栏中被提交的数据是不可见的,这样安全性更好,用户端会通知服务端获取数据,所以这种情况没有数据长度的限制,缺点是速度会慢些。

关于 POST 的注意事项:

将表单数据附加在 HTTP 请求的正文中(不在 URL 中显示提交的表单数据)

POST 没有大小限制,可用于发送大量数据。

带有 POST 的表单提交后无法添加书签

4、enctype —— 编码方式

enctype 属性规定在发送到服务器之前应该如何对表单数据进行编码。

<form enctype="value">

有以下几种值:

含义

application/x-www-form-urlencoded

在发送前编码所有字符(默认编码方式)

multipart/form-data

不对字符编码。

在使用包含文件上传控件的表单时,必须使用该值。

text/plain

以纯文本的方式,空格转换为 "+" 加号,但不对特殊字符编码。

5、target —— 目标显示方式

target 属性规定在何处打开 action URL。表单的目标窗口通常用来显示表单返回的信息,例如是否成功提交了表单,是否出错等。

<form target="value">

属性值有以下:

描述

_blank

在新窗口中打开。

_self

默认。在表单当前的窗口中打开。

_parent

在父窗口中打开。

_top

在顶级窗口中打开。

framename

在指定的框架窗口中打开。

看到这里是不是想的了之前学习超链接时候,a标签也有同样的属性,这里差不多一个意思,只是用途不一样。

这里的窗口有可能是框架 frame 或 浮动窗口 iframe ,后面会讲到框架和浮动窗口,就是在一个页面中可以嵌套一个子窗口。

表单控件的使用

什么是表单控件,就是收集数据的各种形式控件,比如输入框,密码框,单选、多选按钮,下拉菜单,文本域,文件域,提交按钮等等。

如下代码:

<form name="form1">
<div>用户名:<input name="username" type="text" ></div>
<div>密码:<input name="password" type="password" ></div>
<div>性别:
<input type="radio" name="sex" value="male" checked> 男
<br>
<input type="radio" name="sex" value="female"> 女
</div>
<div> 车辆:
<select name="cars">
<option value="volvo">baom</option>
<option value="saab">Saab</option>
<option value="fiat">Fiat</option>
<option value="audi">Audi</option>
</select>
</div>
<div>留言:
<textarea name="message" rows="10" cols="30">
请输入文本
</textarea>
</div>
</select>
  </form>

效果如下:

这里显示了一个基本表单,包含了输入框,密码框,单选,下拉菜单,文本域等组件,下面会按其使用类型介绍表单控件。

所有表单控件都一个name属性和vaule属性,用于和其它控件区别,后台程序将会以此名称获取其表单控件对应的vaule值。

下篇会介绍各种表单控件的使用,感谢关注。

上篇:前端入门——html 表格的使用

下篇:前端入门——html 表单控件使用

何在Spring boot中配置和发送邮件呢,今天我们就以QQ邮件为例,给大家说一下在spring Boot中发送,包括简单邮件,html格式邮件,包含附件的邮件,和发送图片内容的邮件

spring boot配置邮件

1.配置邮件

1.1配置maven依赖

1.2在application.properties中配置发送邮件的用户名 密码等信息

1.3配置QQ邮箱的IMAP/SMTP信息,来配置spring.mail.password的信息

1.3.1登录QQ邮箱,打开设置

1.3.2 点击设置后,点击账号,找到以下模块,点击开启,就可以生成授权码

1.4编写Service

package com.team.base.service;

import lombok.extern.java.Log;

import lombok.extern.log4j.Log4j;

import lombok.extern.slf4j.Slf4j;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.beans.factory.annotation.Value;

import org.springframework.core.io.FileSystemResource;

import org.springframework.mail.SimpleMailMessage;

import org.springframework.mail.javamail.JavaMailSender;

import org.springframework.mail.javamail.MimeMessageHelper;

import org.springframework.stereotype.Service;

import javax.mail.MessagingException;

import javax.mail.internet.MimeMessage;

import java.io.File;

/**

* @com.team.base.service

* @fenghaiju

* @2018/3/19-16:46

* @springBootBase

**/

@Service

@Slf4j

public class MailService {

@Autowired

private JavaMailSender sender;

@Value("${spring.mail.username}")

private String from;

/**

* 发送纯文本的简单邮件

* @param to

* @param subject

* @param content

*/

public void sendSimpleMail(String to, String subject, String content){

SimpleMailMessage message = new SimpleMailMessage();

message.setFrom(from);

message.setTo(to);

message.setSubject(subject);

message.setText(content);

try {

sender.send(message);

log.info("简单邮件已经发送。");

} catch (Exception e) {

log.error("发送简单邮件时发生异常!",e);

}

}

/**

* 发送html格式的邮件

* @param to

* @param subject

* @param content

*/

public void sendHtmlMail(String to, String subject, String content){

MimeMessage message = sender.createMimeMessage();

try {

//true表示需要创建一个multipart message

MimeMessageHelper helper = new MimeMessageHelper(message, true);

helper.setFrom(from);

helper.setTo(to);

helper.setSubject(subject);

helper.setText(content, true);

sender.send(message);

log.info("html邮件已经发送。");

} catch (MessagingException e) {

log.error("发送html邮件时发生异常!",e);

}

}

/**

* 发送带附件的邮件

* @param to

* @param subject

* @param content

* @param filePath

*/

public void sendAttachmentsMail(String to, String subject, String content, String filePath){

MimeMessage message = sender.createMimeMessage();

try {

//true表示需要创建一个multipart message

MimeMessageHelper helper = new MimeMessageHelper(message, true);

helper.setFrom(from);

helper.setTo(to);

helper.setSubject(subject);

helper.setText(content, true);

FileSystemResource file = new FileSystemResource(new File(filePath));

String fileName = filePath.substring(filePath.lastIndexOf(File.separator));

helper.addAttachment(fileName, file);

sender.send(message);

log.info("带附件的邮件已经发送。");

} catch (MessagingException e) {

log.error("发送带附件的邮件时发生异常!",e);

}

}

/**

* 发送嵌入静态资源(一般是图片)的邮件

* @param to

* @param subject

* @param content 邮件内容,需要包括一个静态资源的id,比如:<img src=\"cid:rscId01\" >

* @param rscPath 静态资源路径和文件名

* @param rscId 静态资源id

*/

public void sendInlineResourceMail(String to, String subject, String content, String rscPath, String rscId){

MimeMessage message = sender.createMimeMessage();

try {

//true表示需要创建一个multipart message

MimeMessageHelper helper = new MimeMessageHelper(message, true);

helper.setFrom(from);

helper.setTo(to);

helper.setSubject(subject);

helper.setText(content, true);

FileSystemResource res = new FileSystemResource(new File(rscPath));

helper.addInline(rscId, res);

sender.send(message);

log.info("嵌入静态资源的邮件已经发送。");

} catch (MessagingException e) {

log.error("发送嵌入静态资源的邮件时发生异常!",e);

}

}

}

1.5编写Controller

package com.team.base.controller;
import com.team.base.service.MailService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
 * @com.team.base.controller
 * @fenghaiju
 * @2018/3/19-16:51
 * @springBootBase
 **/
@RestController
@RequestMapping("/mail")
public class MailController {
 @Autowired
 private MailService mailService;
 /**
 * 简单发送
 * @return
 */
 @RequestMapping("/sendSimpleMail")
 public ResponseEntity<?> sendSimpleMail(){
 mailService.sendSimpleMail("fenghaiju@sohu.com", "简单邮件", "简单的邮件测试");
 return ResponseEntity.ok(true);
 }
 /**
 * 发送html内容
 * @return
 */
 @RequestMapping("/sendHtmlMail")
 public ResponseEntity<?> sendHtmlMail(){
 mailService.sendHtmlMail("fenghaiju@sohu.com", "html邮件", "<html><body><h3>你好, 这是一封模板邮件!</h3></body></html>");
 return ResponseEntity.ok(true);
 }
 /**
 * 发送附件
 * @return
 */
 @RequestMapping("/sendAttachmentsMail")
 public ResponseEntity<?> sendAttachmentsMail(){
 mailService.sendAttachmentsMail("fenghaiju@sohu.com", "附件邮件", "测试邮件内容","D:\\article\\结尾.txt");
 return ResponseEntity.ok(true);
 }
 /**
 * 发送图片
 * @return
 */
 @RequestMapping("/sendInlineResourceMail")
 public ResponseEntity<?> sendInlineResourceMail(){
 mailService.sendInlineResourceMail("fenghaiju@sohu.com", "发送图片", "<img src=\"cid:rscId01\" >","D:\\article\\架构师.png","rscId01");
 return ResponseEntity.ok(true);
 }
}
 

1.6测试邮件

1.6.1测试简单邮件

1.6.2 测试Html格式邮件

1.6.3 测试附件邮件

1.6.4 测试图片邮件

2.总结,大家在配置邮件的时候,注意配置文件的空格,否则会出现异常情况

TML的pre标签

定义和用法

<pre> 标签定义预先格式化的文本。

<pre> 元素中的文本以等宽字体显示,文本保留空格和换行符。文本将完全按照 HTML 源代码中所写的方式显示。

使用(保留原有格式),和div区别

执行结果如下:

在layui中使用,未使用pre,结果如下:在一行显示,不太好看和理解

layer.alert(JSON.stringify(data,null,4));

使用pre标签后,结果如下:json格式化展示出来了,易于理解和好看,方便分析。

layer.alert("<pre>"+JSON.stringify(data,null,4)+"</pre>");


2024-2-26