DEV Community

Cover image for Self-Hosted Form API for Static Sites - Form2Mail vs. Formspree vs. Google Forms
Daniel T Sasser II
Daniel T Sasser II

Posted on • Edited on • Originally published at dansasser.me

Self-Hosted Form API for Static Sites - Form2Mail vs. Formspree vs. Google Forms

Form2Mail vs. Formspree vs. Google Forms
Form2Mail vs. Formspree vs. Google Forms

A fair comparison of Form2Mail vs. Formspree vs. Google Forms

Introduction

GOROMBO is a software development company that specializes in creating custom apps, software, and APIs designed to integrate seamlessly with digital storefronts and point-of-sale (POS) systems. Their solutions streamline business operations and improve customer interactions, helping businesses manage everything from e-commerce to in-person sales efficiently.

One of Gorombo’s latest products, Form2Mail, offers a powerful tool for static websites that need to handle dynamic form submissions securely. As static websites grow in popularity for their speed, simplicity, and security, they often face a significant limitation: static sites don’t support backend functionalities like handling form submissions. Many businesses turn to cloud-based solutions such as Google Forms or Formspree for this purpose, but these services come with notable drawbacks—subscription fees, limited customization, and potential security risks due to external data handling.

Form2Mail addresses these challenges by offering a self-hosted, flexible API that gives developers full control over form submissions on static websites. Built with FastAPI and SMTP, Form2Mail processes form data directly on your server, ensuring maximum security without ongoing costs or limitations. It’s especially suited for developers seeking to maintain control over their data while eliminating reliance on third-party servers.

In this article, we will explore why self-hosted form submission APIs like Form2Mail are essential for static websites, and how it stacks up against cloud-based alternatives like Formspree and Google Forms.

Why Static Sites Need Custom Form APIs

Static sites are fast and secure because they don’t rely on server-side code. However, this also means that functions like processing contact forms are missing, requiring the integration of external services to manage form data and send email notifications. Popular services like Formspree offer easy setup but operate on a subscription basis, charging more as your usage grows.

Additionally, many developers have concerns about data security when using third-party services, as form data is handled on external servers. A self-hosted solution like Form2Mail gives developers more control over their data, costs, and customization options.

Why Self-Hosted Forms Outperform Google Forms in Security and SEO

In the realm of digital interactions, web forms play a critical role—but not all form services are created equal. Public platforms, such as Google Forms, offer convenience but come with inherent risks. Hackers exploit these services to deceive users and steal personal information. Self-hosted forms, like Form2Mail, offer a more secure solution, empowering businesses with data control and reducing phishing risks.


Real-World Phishing Threats: Risks of Using Public Forms

Cybercriminals exploit public form platforms by embedding malicious forms into emails. In one campaign, attackers tricked users into submitting Office 365 credentials via a compromised Google Form. Another example involved an AutoIT script stealing system information, sending it to a hidden Google Forms endpoint for further use.

These incidents highlight the danger of relying on public platforms that attackers can manipulate to bypass security. Since users trust familiar platforms like Google, they are often more vulnerable to these phishing tactics.

Introducing Form2Mail: The Best Self-Hosted Form API

Form2Mail is a custom-built, self-hosted solution using FastAPI and SMTP to handle form submissions securely and efficiently. It’s designed for developers who want more control over form data, avoid subscription fees, and need a flexible solution for handling forms across multiple projects.

Key Features of Form2Mail:

  • Self-Hosting: You manage your own server and SMTP configuration, giving you full control over where and how form data is processed.
  • FastAPI for Speed: Built with FastAPI, Form2Mail processes form submissions quickly and efficiently, even for high-traffic sites.
  • SMTP Email Delivery: Form submissions are emailed via SMTP with customizable sender and recipient details, making it adaptable for any project.
  • API Key Authentication: Ensures only authorized requests are processed, securing your forms against spam and unauthorized submissions.
  • Cost-Effective: Form2Mail eliminates the recurring fees of third-party services, making it ideal for developers handling multiple websites or projects with high traffic.

Top Benefits of Self-Hosted Forms for Security & SEO Success

Switching to self-hosted forms, such as Form2Mail, gives businesses control over data flow and reduces vulnerabilities. Unlike public platforms, self-hosted forms are directly tied to your domain, increasing user trust and ensuring all interactions remain under your control.

Beyond security, self-hosting offers SEO advantages. Keeping users on your domain improves engagement metrics, reduces bounce rates, and enhances your site's ranking potential. For tips on how user engagement impacts SEO, see Moz's SEO Guide.

Form2Mail vs. Formspree vs. Google Forms: Comparing Self-Hosted and Cloud Form Submission Solutions for Static Sites

Race to Form Success: The Great Form Showdown!
Race to Form Success: The Great Form Showdown

When choosing a form submission tool for static websites, developers must weigh the benefits of self-hosted and cloud-based solutions. Let’s compare Form2Mail, Formspree, and Google Forms based on pricing, customization, and advanced features.

Formspree Overview

Formspree is a cloud-based form submission service that provides an easy setup for handling forms on static websites by using an action URL directly in the HTML form. It’s popular for its simplicity and ease of integration.

  • Pricing: Formspree offers a free tier with up to 50 form submissions per month, but once you exceed that limit, paid plans start at $10 per month.
  • Customization: While it supports AJAX form submissions and basic spam protection like reCAPTCHA, Formspree’s design customization is limited. Advanced features, such as integrations and form validation rules, require paid plans.
  • Security: Formspree processes data through its servers, which may raise security concerns for sensitive information. Although the service does provide TLS encryption, it does not offer the same control as self-hosted alternatives like Form2Mail.

Learn more about Formspree’s pricing and features.

Google Forms Overview

Google Forms is a free form-building tool popular for simple surveys and data collection tasks. While easy to use, it has significant limitations that may deter developers working on more advanced static sites.

  • Pricing: Google Forms is free, with no limits on the number of forms or submissions, making it a great choice for basic use.
  • Customization: Google Forms is restricted in terms of design. You can't fully customize the form to match your website’s branding, which might lead to inconsistent visual elements.
  • Advanced Features: Google Forms lacks the ability to handle more complex workflows, such as advanced conditional logic or multi-step forms. Additionally, it has no native integrations for payment processing, limiting its usability for businesses that need to handle transactions.
  • Security: While it offers basic security features like SSL encryption, file upload restrictions require users to be logged into Google, which can disrupt the user experience. Moreover, Google Forms does not support file uploads without requiring Google account authentication, limiting accessibility.

Learn more about Google Forms limitations and usage.

Form2Mail Overview

Form2Mail is a fully customizable, self-hosted form submission API that is ideal for static site developers who need complete control over their data and functionality. It offers unmatched flexibility, security, and scalability.

  • Pricing: Form2Mail is open-source and free to use under the Apache 2.0 Licence, making it highly cost-effective compared to subscription-based services like Formspree.
  • Customization: Unlike Google Forms or Formspree, Form2Mail gives you full control over the form’s design and functionality. You can adjust everything from field validation to SMTP configurations, ensuring your form integrates seamlessly with your website’s branding.
  • Advanced Features: With Form2Mail, you can implement advanced logic, custom error handling, and API key authentication, ensuring secure and customized form submissions. This level of control is unmatched by cloud-based alternatives.
  • Security: Since it’s self-hosted, all data is processed on your server, which means you don’t rely on third-party servers to handle sensitive information. This provides greater security for businesses handling private user data.

Explore the Form2Mail GitHub Repository to learn more.

Which Solution Should You Choose?

  • Google Forms: Best suited for basic surveys or quizzes, especially if you're looking for a free solution with no customization needs. However, it lacks advanced features, customization options, and security measures, which can limit its usability for business and e-commerce websites.
  • Formspree: Ideal for developers who need a quick and simple setup but are okay with paying monthly fees for advanced features and integrations. Its limited customization and reliance on third-party servers make it less appealing for users needing more control over data security and branding.
  • Form2Mail: Perfect for developers managing static websites who require complete control over form functionality, security, and customization. With no ongoing fees and full server-side processing, Form2Mail provides a flexible, cost-effective solution that scales with your needs.

Step-by-Step Setup Guide for Form2Mail

Step-by-Step Setup Guide for Form2Mail
Follow these quick and easy steps to get started with Form2Mail

Form2Mail is simple to set up and deploy, yet highly customizable. Here’s a detailed guide to getting it up and running on your server:

Prerequisites

  • Python 3.8 or higher
  • pip (Python’s package manager)
  • virtualenv (optional but recommended)
  • SMTP credentials
  • FastAPI and uvicorn for server deployment

Installation Steps

  1. Clone the Repository
   git clone https://github.com/dansasser/form2mail.git
   cd form2mail
Enter fullscreen mode Exit fullscreen mode
  1. Configure Environment Variables
   mv .env.example .env
Enter fullscreen mode Exit fullscreen mode

Edit the .env file:

   SMTP_SERVER=smtp.yourserver.com
   SMTP_PORT=465
   EMAIL_SENDER=noreply@yourdomain.com
   EMAIL_RECEIVER=admin@yourdomain.com
   EMAIL_PASSWORD=your-smtp-password
   API_KEY=your-api-key
Enter fullscreen mode Exit fullscreen mode
  1. Run Installation Script
   ./installer.sh
Enter fullscreen mode Exit fullscreen mode
  1. Manual Setup (Optional)
   python3 -m venv venv
   source venv/bin/activate
   pip install -r requirements.txt
   uvicorn main:app --host 0.0.0.0 --port 3081
Enter fullscreen mode Exit fullscreen mode

Sending a Test Request

Use cURL or fetch to send a test request to the API:

curl -X POST http://localhost:3081/send-email/ \
  -H 'Content-Type: application/json' \
  -H 'x-api-key: your-api-key' \
  -d '{
    "name": "Jane Doe",
    "email": "jane.doe@example.com",
    "subject": "Test Inquiry",
    "message": "This is a test submission."
  }'
Enter fullscreen mode Exit fullscreen mode

Customization

Form2Mail is highly customizable; you can adjust validation fields, error handling, and email formatting by editing files like contact.py and email_service.py.


Best Practices for Self-Hosting Forms

To maximize the security and SEO benefits of Form2Mail, implement the following best practices:

Implement SSL Encryption

Ensure all data transmissions are encrypted to protect sensitive user information. Learn more about SSL certificates from Let’s Encrypt.

Use CAPTCHA for Spam Protection

Add Google CAPTCHA to prevent bots from spamming your forms.

Ensure GDPR Compliance

Keep form data within your infrastructure and align with data privacy laws like GDPR. Visit the EU GDPR Portal for compliance resources.

Display a Privacy Policy

Communicate clearly with users by publishing a privacy policy outlining how their data is collected and protected.

Best Practices for Form Handling on Static Sites

Handling form submissions on static sites requires attention to spam prevention, validation, and security.

1. Spam Prevention

  • Honeypot Fields: Add hidden fields to detect bots.
  • reCAPTCHA: Use Google's reCAPTCHA to prevent spam.
  • Rate Limiting: Limit the number of form submissions per IP.

2. Validation

  • Client-Side Validation: Use JavaScript to validate user inputs before submission.
  • Server-Side Validation: Always validate on the server side using Pydantic models.

3. Security Measures

  • Use HTTPS: Always secure form data with HTTPS.
  • API Key Authentication: Secure the API with keys to prevent unauthorized access.
  • Avoid Storing Sensitive Data: Minimize storage of sensitive user data unless necessary.

4. Error Handling

  • Graceful Failure: Provide clear error messages for failed submissions.
  • Logging: Implement logging to detect spam and unauthorized access.

Other Gorombo Tools to Boost Your Development Workflow

Gorombo Tools
GOROMBO Software & Web Development | Cloud Hosting | Email Hosting | VPS Hosting | Custom Software | API Integration

Astro SSR SPA

The Astro SSR SPA Template is one of Gorombo's most powerful tools, designed for developers building modern web applications. It combines the best of server-side rendering (SSR) and single-page application (SPA) functionality, making it ideal for high-performance projects like e-commerce sites, portfolios, or dynamic blogs.

  • Key Features:
    • Astro SSR Integration: This template leverages Astro’s server-side rendering to ensure fast load times and dynamic content updates.
    • HTMX for SPA Functionality: With HTMX, content dynamically loads and swaps without requiring full page reloads, offering a seamless user experience.
    • Tailwind CSS & DaisyUI: Pre-configured with Tailwind CSS and DaisyUI, allowing for rapid UI development while maintaining full customization capabilities.
    • MongoDB Integration: Built-in support for MongoDB ensures that you can scale your applications easily with database-driven functionality.
    • Express.js Middleware: Express.js is used for server-side logic and routing, giving developers the flexibility to handle custom backend needs.

To get started, clone the repository and follow the setup instructions provided:
Astro SSR SPA GitHub Repository

This template is a game-changer for developers looking for an efficient way to combine SSR with SPA architecture in a single project.

Background Remover Micro-App

Another innovative tool from Gorombo, the Background Remover Micro-App uses AI to automatically remove image backgrounds, making it particularly useful for e-commerce, marketing, and design purposes. By leveraging this tool, developers and non-technical users can quickly process images without needing advanced photo-editing skills.

  • Key Benefits:
    • AI-Powered: Uses artificial intelligence to precisely detect and remove backgrounds from images.
    • Micro-App: Lightweight and easy to integrate into any web application.
    • Time Saver: Ideal for businesses or individuals who need to handle bulk image processing efficiently.

For developers interested in integrating this app into their workflow:
Background Remover Micro-App GitHub Repository

Customer Email Automation

Automating customer communication is essential for businesses looking to scale their operations efficiently. Customer Email Automation is designed to help businesses manage onboarding, follow-ups, and other customer engagement activities.

  • Key Features:
    • Automated Workflow: Set up custom workflows to automatically send emails based on triggers like new user registrations, purchases, or other events.
    • Customizable Templates: Includes pre-built templates that can be customized for specific business needs.
    • Integration Ready: Easily integrates with existing CRM systems or custom databases to manage customer interactions seamlessly.

Start automating your customer emails today with:
Customer Email Automation GitHub Repository


Conclusion: Form2Mail – The Cost-Effective Alternative with Security and SEO Benefits

In a digital world increasingly vulnerable to phishing attacks and data breaches, businesses can no longer afford to rely solely on public platforms like Google Forms for critical user interactions. While Google Forms and Formspree provide ease of use and basic functionality, their limitations in customization, security, and data control make them unsuitable for businesses seeking to build secure, scalable solutions.

Form2Mail offers a secure, self-hosted alternative that ensures businesses maintain complete control over data flow, reducing the risks of phishing and unauthorized access. By processing form submissions on your own server, Form2Mail not only safeguards sensitive data but also eliminates recurring subscription fees, making it a cost-effective solution for developers managing multiple websites or high-traffic projects.

Additionally, self-hosting forms directly on your website brings SEO advantages, such as improved on-page engagement and reduced bounce rates. Keeping users on your domain rather than redirecting them to third-party services enhances your site's ranking potential and strengthens brand trust.

Whether you’re running a blog, e-commerce site, or enterprise-level project, Form2Mail offers a scalable and flexible way to manage form submissions with security and business value in mind. It combines the best of security-first principles with SEO optimization, empowering businesses to stay ahead of cyber threats while fostering user trust and engagement.

Ready to streamline your form submissions with a secure and cost-effective solution?

Visit Form2Mail on GitHub and explore the setup guide to get started today!


FAQs

  1. Why is Form2Mail a safer alternative?

    Form2Mail ensures data stays on your server, reducing risks from third-party services. For more guidance, see OWASP's Server Security Guide.

  2. How do self-hosted forms improve SEO?

    Self-hosted forms boost engagement metrics by keeping users on your site. Read more on SEO best practices from Moz.

  3. Can Form2Mail help with compliance?

    Yes, Form2Mail offers full control over data, aiding compliance with GDPR and CCPA. Visit the CCPA Portal for more information.


Resources

  • Form2Mail GitHub Repository - Explore the open-source Form2Mail repository, a self-hosted API for handling form submissions on static websites using FastAPI and SMTP. You’ll find setup instructions, configuration tips, and more.

  • Formspree Documentation - For a cloud-based alternative, check out Formspree, which provides easy form handling for static sites. The documentation covers features, pricing tiers, and API details.

  • Google Forms Help Center - Learn how to create and manage forms with Google Forms. This resource covers how to build forms, collect responses, and integrate with Google Sheets. Keep in mind its limitations for advanced use cases.

  • Astro SSR SPA GitHub Repository - Dive into Gorombo’s Astro SSR SPA template, which combines server-side rendering (SSR) with single-page application (SPA) functionality. Ideal for fast, high-performance web apps, especially in e-commerce settings.

  • Background Remover Micro-App GitHub Repository - A micro-app powered by AI that automates background removal from images, perfect for marketing or design projects. Get the source code and see how it integrates with web applications.

  • Customer Email Automation GitHub Repository - Automate email workflows with Customer Email Automation to manage onboarding, follow-ups, and other customer engagement tasks. This tool easily integrates into existing CRM systems or custom databases.

  • Python Official Documentation - Form2Mail is built using Python, and this official documentation is an excellent resource for learning how to set up Python environments, manage packages with pip, and use virtual environments in your projects.

  • FastAPI Official Documentation - Form2Mail is built using FastAPI, and this official documentation is an excellent resource for learning how to set up FastAPI and use it in your projects.

  • SMTP Official Documentation - Form2Mail is built using SMTP, and this official documentation is an excellent resource for learning how to set up SMTP in your projects.

  • GOROMBO - GOROMBO Web Development | Email Hosting | VPS Hosting | Cloud Hosting | Custom Software | API Integration

  • GOROMBO on Facebook - Keep up to date with the latest news and updates from GOROMBO on Facebook.


References


Support My Work

If you enjoy my projects and want to support my work, consider buying me a coffee!

DigitalOcean Referral Badge

Top comments (0)