惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

B
Blog
Apple Machine Learning Research
Apple Machine Learning Research
P
Privacy & Cybersecurity Law Blog
Cyberwarzone
Cyberwarzone
Hugging Face - Blog
Hugging Face - Blog
C
Cybersecurity and Infrastructure Security Agency CISA
Microsoft Azure Blog
Microsoft Azure Blog
A
About on SuperTechFans
Y
Y Combinator Blog
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
博客园_首页
P
Privacy International News Feed
AWS News Blog
AWS News Blog
F
Future of Privacy Forum
H
Help Net Security
Cisco Talos Blog
Cisco Talos Blog
月光博客
月光博客
N
Netflix TechBlog - Medium
I
InfoQ
S
Securelist
V
V2EX
博客园 - 聂微东
Last Week in AI
Last Week in AI
T
Tenable Blog
T
The Exploit Database - CXSecurity.com
Recorded Future
Recorded Future
阮一峰的网络日志
阮一峰的网络日志
The Hacker News
The Hacker News
GbyAI
GbyAI
博客园 - Franky
T
Tor Project blog
Blog — PlanetScale
Blog — PlanetScale
F
Fortinet All Blogs
博客园 - 司徒正美
M
Microsoft Research Blog - Microsoft Research
V
Vulnerabilities – Threatpost
T
Threat Research - Cisco Blogs
T
ThreatConnect
T
True Tiger Recordings
T
Threatpost
F
Full Disclosure
C
CXSECURITY Database RSS Feed - CXSecurity.com
Know Your Adversary
Know Your Adversary
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
C
Cisco Blogs
博客园 - 【当耐特】
F
Fox-IT International blog
G
GRAHAM CLULEY
雷峰网
雷峰网
Google DeepMind News
Google DeepMind News

DEV Community

Less Toil, More Flow - Automating the Path from Request to Implementation The Code Review Checklist I Actually Use How I run a small blog on Astro 5 + Content Collections Git: Best Practices for Professionals How IBM Bob Became My Everyday Coding Companion I built a small browser puzzle game about arrows I wrapped Claude Code in a zsh function. Here's every decision I almost got wrong. Mobile Game Optimization: A Unity Developer's Checklist Git: Best Practices for Beginners Three days I lost chasing a ghost that was already dead on disk Why Too Many Parts Hurt ClickHouse Performance Guardrails for Agent Output: Pluggable Validation Before and After LLM Calls Gemma Forge: Local AI Without the Setup Wall From Half‑dead Prototype to Local‑Only AI Medical Assistant: Rewiring MedClinic with GitHub Copilot Runninig a forkbomb in Jenkins What’s Actually Happening When You Use Git Preventing Recursive Tool Loops in LangChain Agents Building a Rock-Paper-Scissors CLI with TypeScript — Union Types, Conditionals, and Jest Your AI Coding Agent Wastes 80% of Its Context. Fixed That with Graph Theory. Why Flutter Has Become the Go-To Framework for Fintech App Development We built a scripting language just for AI agents. Here's why. Stop building AI inboxes. Build decision layers instead. Meme Monday Why I Built @editora/ui-react? Are AI tools the next level of abstraction in software development? Identity on Solana: Your Wallet Is Your Account One API Call Changed Everything The Internet Career Nobody Talks About Enough: What Is DevRel? Solar Panel Wiring Diagram: Series vs Parallel Hello everyone! Glad to join the dev.to community I Built an AI Agent That Tailors My Resume - Here's How Agents Actually Work I Built a WhatsApp OTP + AI Chatbot Platform for African Businesses MTP Explained — And Why It Matters for Android on Mac Most Beginners Learn Full-Stack Development Backwards GitHub Glow-Up: Open Source, READMEs, Badges, Streaks, Git and gh CLI System Design Cheat Sheet: Concepts Every Developer Should Know Are Junior Developer Roles Actually Dying? A Fresher's Honest Take Using DigitalOcean Droplets as Ephemeral Sandboxes for AI Agents I built a VSCode extension that visualises your code navigation as a call tree — made for legacy codebase pain Vite predev/prebuild: chaining scripts without losing your mind A website to save you from messy browser tabs Dear Web2 Developer... Solana is here calling Postgres JSONB indexes: GIN vs BTREE on the same column The $5 AI That Remembers Everything What are your goals for the week? #180 Zettelkasten for Developers: A Practical Method That Works OpenClaw vs Hermes Agent: Stars, Downloads & Usage 2026 `act` vs. `waitFor` Global Teams Don’t Struggle With Time Zones. They Struggle With Context Python as a JavaScript Dev $5.4 Billion in Damage. 8.5 Million Machines Down. Three YAML Controls Would Have Prevented It. Here's the Structural Analysis. 🚫 Stop Using PN532 V1 for Your NFC Projects (Real Debugging Experience) Probabilistic Graph Neural Inference for smart agriculture microgrid orchestration for extreme data sparsity scenarios Inference Is Becoming the New Steady-State Cost Center Why AI-Generated Code Is Always Good Enough — And Never Great I built a dark admin dashboard template in HTML — no React, no npm, just pure HTML What is the Difference Between Lattice-Based and Hash-Based Signatures? Next.js App Router caching: revalidate, dynamic, and no-store without the folklore Next.js App Router caching: revalidate, dynamic y no-store sin folklore I built Stashly — a full-stack content manager with a rich text editor published: false tags: react, node, mongodb, typescript Why I Started Building React Projects Instead of Just Watching Tutorials ? Every Tool Eventually Becomes Tuesday Nobody Warns You That Real Software Engineering Feels Chaotic Tích hợp VNPay, Stripe trong Odoo 19 BeautifulSoup and Requests for Web Scraping With Python: When Simple Still Works I Was Stuck Debugging React — Then Developer Tools Changed It Buck Converter Ripple: Sizing the Inductor and Capacitor With Confidence AWS Just Made Its MCP Server Generally Available. Here's What It Actually Gives AI Agents. RAMPART Tests Your AI Agents in Dev. What Catches Malicious Tool Calls in Production? Vibe Team Software Engineering: What a Real AI Human Dev Team Workflow Actually Looks Like An npm Package for AI Agent Orchestration Just Shipped With Its Front Door Unlocked. Here's What the CVE Actually Reveals. Microsoft Foundry Just Added CI/CD for AI Agents. Here's What That Actually Changes. The Best Career Insurance Is a Tech Event You Don't Want to Attend Your GitHub Profile Already Tells Recruiters More Than Your Resume. Most Devs Just Don't Surface It. How to Add Execution Budgets to OpenAI Agents SDK Binary Tree Interview Problems: 6 Traversal Patterns, 15 Problems We trained a personal voice DoRA on Qwen3-8B for $1.50 — beat stock model 100% in blind A/B Stop Leaking API Keys: Why I Built a Local-First Vault for Developers 🔐 RAG Explained: How Retrieval-Augmented Generation Actually Works I Built a Fast Async JioSaavn API Wrapper in Python 🎧 chown & chgrp Deploying Your First App on Kubernetes: A Beginner's Guide (Minikube & Kind) Logs in code It's called a PR "review" for a reason DePIN GPU Market: The Failed Job Receipt Developers Should Demand Why Your AI Agent Monitoring is Wrong (And How to Fix It) Lock Down Your Cloud Shares: A Beginner’s Guide to Azure Files Security. Building a Multi-Channel Content Syndication Pipeline with EmDash Plugins Turn Your Phone Into Voice Input for Any React Text Field Which package is bloating your Docker image? Putting Claude Code Under Version Control: Configs Since July, Memory Since April What I Thought DevRel Was vs. What It Actually Is (A Mentee's Honest Take) What I Thought DevRel Was vs. What It Actually Is (A Mentee's Honest Take) 400 Million Tokens Burned Overnight Reviving My Linux Mastery Game from a Merge Conflict — A Finish-Up-A-Thon Comeback Don’t let AI break your collective thinking: a practical guide for engineering teams First Gemma 4 ExecuTorch Deployment on Raspberry Pi 5 — and Why It's 7.7 Slower Than llama.cpp Per-Turn Evaluation: Dynamic Governance for AI Agents The AI Triforce of seed4j: Power, Wisdom, and Courage for Your Dev Agent Your AI agent reports 80% task completion. It fabricated it.
Solana Passkey Wallet: Replacing Seed Phrases with SIMD-0075
VaultKeepR · 2026-05-25 · via DEV Community

Solana Passkey Wallet: Replacing Seed Phrases with SIMD-0075

The perennial developer lament of "lost seed phrase" may finally be nearing its end, not through better memorization, but through a fundamental shift in cryptographic primitives available on-chain. The Solana passkey wallet paradigm leverages device-native biometrics to eliminate seed phrase exposure entirely, and SIMD-0075 makes this possible at the protocol level.

In June 2025, Solana activated SIMD-0075 on mainnet, introducing a new precompile for the on-chain verification of secp256r1 (P-256) signatures. This is a critical development because P-256 is the elliptic curve underpinning WebAuthn passkeys, the same technology securing Face ID, Touch ID, Windows Hello, and YubiKeys. For the first time, a major Layer 1 blockchain can natively verify passkey signatures directly on-chain. This is not merely a Solana-specific upgrade; it signals the broader convergence of Web2 and Web3 authentication, enabling the same cryptographic primitives that secure your password manager to secure your crypto wallet, eliminating seed phrases and central server trust.

Let's dissect the technical implications, the persistent curve mismatch problem, and the architectural solutions now empowering developers to build truly passwordless, self-sovereign applications.

1. How Do Passkeys Differ from Traditional Crypto Wallets?

Web2: WebAuthn & Passkeys

Modern passwordless authentication, standardized by WebAuthn (built on the FIDO2 protocol), operates on a robust security model. When you log in with a biometric, this is the underlying process:

  1. Your device's secure hardware module (e.g., Apple's Secure Enclave, Android's Trusted Execution Environment, or a TPM on Windows) generates a public-private key pair.
  2. The private key is immutably confined within this secure enclave, never exposed to the operating system or applications.
  3. The public key is registered with the service provider.
  4. For authentication, you approve a challenge via biometrics. The secure enclave signs this challenge with the private key.
  5. The service verifies the signature against your registered public key.

The curve of choice for WebAuthn is P-256 (secp256r1). It's the only elliptic curve uniformly supported by Apple's Secure Enclave and Android Keystore, is NIST-approved, FIPS-compliant, and embedded in billions of devices globally.

Web3: Crypto Wallets & Seed Phrases

Traditional crypto wallets employ a distinct, and often problematic, security architecture:

  1. A seed phrase (typically 12 or 24 BIP-39 words) is generated, serving as the root of all cryptographic keys.
  2. This seed deterministically derives private keys for various blockchain accounts.
  3. The user bears the sole responsibility of securely storing this seed phrase, either physically or digitally.
  4. To sign a transaction, the private key derived from the seed is loaded into memory (e.g., within a browser extension, mobile app, or hardware wallet).
  5. The signature is then verified on-chain using the corresponding public key.

Elliptic curves vary across chains:

  • Ethereum/Bitcoin: secp256k1
  • Solana: Ed25519 (Curve25519)
  • Polkadot/Cardano/Stellar: Ed25519

The fundamental divergence lies here: Web2 passkeys ensure the private key never leaves secure hardware. Crypto wallets, by design, frequently expose private keys to software memory. A seed phrase can be compromised through physical theft or digital capture. A private key in a browser extension is vulnerable to malware, as demonstrated by numerous supply chain attacks.

2. What Is the Curve Mismatch Between P-256 and Ed25519?

The core technical hurdle has been the curve mismatch. WebAuthn passkeys exclusively use P-256 (secp256r1), while Solana primarily uses Ed25519. These are distinct elliptic curves employing different signature schemes (ECDSA vs. EdDSA) and are cryptographically incompatible.

Property P-256 (secp256r1) Ed25519
Used by WebAuthn, FIDO2, HSMs, Apple/Google Solana, Signal, SSH
Signature scheme ECDSA EdDSA
Deterministic No (requires random nonce k) Yes
NIST-approved Yes No
Browser API support Yes (WebAuthn) No
Secure Enclave support Yes (all platforms) No (Apple/Google don't expose)

This incompatibility means a passkey residing in your iPhone's Secure Enclave cannot natively sign a Solana transaction. The browser's WebAuthn API does not provide an interface for Ed25519 signing from secure hardware. You cannot simply invoke navigator.credentials.get() and expect an Ed25519 signature suitable for Solana.

SIMD-0075 addresses a critical part of this problem. By introducing a precompile at address Secp256r1SigVerify1111111111111111111111111, Solana can now perform on-chain verification of P-256 signatures. This allows Solana programs to accept passkey signatures as proof of identity or authorization.

However, the second half of the problem persists: Solana transactions still mandate Ed25519 signatures. While you can verify a passkey login on-chain, you cannot use that passkey to directly sign a token transfer or smart contract interaction.

3. How Does Decoupling Authentication from Authorization Solve Passkey Signing?

The elegant solution, championed by projects like Para and Helius, involves separating the concerns of authentication from authorization.

Rather than attempting to force a passkey to directly sign Ed25519 transactions, the passkey is leveraged as an authorization primitive:

┌─────────────────┐     ┌──────────────────┐     ┌─────────────────────┐
│  Passkey (P-256) │────>│  Session Token    │────>│  MPC Ed25519 Signer  │
│  (Secure Enclave) │     │  (Scoped + TTL)  │     │  (Key shards)        │
└─────────────────┘     └──────────────────┘     └─────────────────────┘
                                                         │
                                                         ▼
                                                 ┌─────────────────────┐
                                                 │  Solana Transaction  │
                                                 │  (Ed25519 signed)   │
                                                 └─────────────────────┘

Enter fullscreen mode Exit fullscreen mode

The detailed flow:

  1. A user authenticates using their WebAuthn passkey (Face ID, fingerprint, etc.), proving control over their device.
  2. The passkey signs an authorization challenge, establishing a scoped session with a defined time-to-live (TTL).
  3. This session grants access to an Ed25519-compatible signing key managed by Multi-Party Computation (MPC) infrastructure.
  4. The MPC signer then produces the necessary Ed25519 signature for the Solana transaction.
  5. The fully signed transaction is submitted and verified on-chain using Solana's native Ed25519 verification.

The developer impact:

This architectural pattern mirrors how a zero-knowledge password manager like VaultKeepR operates. Your biometric authenticates, unlocking a locally-derived encryption key (e.g., via Argon2id + XChaCha20-Poly1305) that decrypts your vault. The server never observes your master password or unencrypted data. The private key remains device-bound.

Applied to Web3, your biometric unlocks a session that authorizes an MPC-managed signing key. The seed phrase is never loaded into memory. Private key shards are distributed. This eliminates the need to ever ask a user for a seed phrase again.

4. How Do VaultKeepR's Design Principles Apply to Passkey Wallets?

The design philosophy of VaultKeepR provides a direct blueprint for passkey-based crypto wallets:

VaultKeepR Passkey Wallet
Login via fingerprint/Face ID Login via passkey (biometric)
No email, no account No seed phrase, no custodial server
Argon2id key derivation on-device Secure Enclave key generation on-device
XChaCha20-Poly1305 local encryption MPC-managed Ed25519 signing
IPFS decentralized backup Distributed key shards
Shamir 3-of-5 fragmented recovery Social recovery / multi-sig

The core insight is that users prioritize proving their identity over managing complex cryptographic keys. A crypto wallet demanding a 24-word seed phrase is making the same user experience error as a password manager requiring a complex master password for every login. Both should leverage device-native secure hardware to simply ask, "Are you who you say you are?"

5. How to Build Passkey Authentication for Solana (Step-by-Step)

Here's a practical code example demonstrating this pattern using Para's SDK on Solana. The key takeaway is that the passkey's role is to authorize the session, not to directly sign the transaction.

// Step 1: Wrap your app with ParaProvider
import { ParaProvider } from '@getpara/react-sdk';

<ParaProvider
  paraClientConfig={{
    env: Environment.BETA,
    apiKey: process.env.NEXT_PUBLIC_PARA_API_KEY,
  }}
  paraModalConfig={{
    oAuthMethods: ["GOOGLE", "TWITTER", "TELEGRAM"],
    authLayout: ["AUTH:FULL", "EXTERNAL:FULL"],
    recoverySecretStepEnabled: true,
  }}
>
  <YourApp />
</ParaProvider>

// Step 2: Register a passkey on user action
const registerPasskey = async () => {
  // This invokes the browser's WebAuthn API, triggering biometrics
  const passkeyCredential = await navigator.credentials.create({
    publicKey: {
      challenge: new Uint8Array(32), // Random challenge from server
      rp: { name: "Your App" }, // Relying Party ID
      user: {
        id: new Uint8Array(16), // Unique user ID
        name: "user@example.com",
        displayName: "User",
      },
      pubKeyCredParams: [
        { type: "public-key", alg: -7 }, // ES256 (P-256)
      ],
      authenticatorSelection: {
        authenticatorAttachment: "platform", // Use device's built-in authenticator
        requireResidentKey: true, // Create a discoverable credential
      },
    },
  });

  // Register with Para's backend, establishing a scoped session
  await para.registerPasskey(passkeyCredential);
};

// Step 3: Sign and submit a Solana transaction using the established session
import { Connection, Transaction } from '@solana/web3.js';
import { ParaSolanaWeb3Signer } from '@getpara/solana-web3.js-v1-integration';

const connection = new Connection(process.env.HELIUS_RPC_URL);
const solanaSigner = new ParaSolanaWeb3Signer(para, connection);

const transaction = new Transaction().add(/* your instruction */);
const signedTx = await solanaSigner.signTransaction(transaction);
await connection.sendRawTransaction(signedTx.serialize());

Enter fullscreen mode Exit fullscreen mode

Cryptographic breakdown:

  1. navigator.credentials.create() directs the device's Secure Enclave to generate a P-256 key pair.
  2. The P-256 private key remains securely within the enclave, protected by biometrics.
  3. Para utilizes the generated passkey credential to establish a signed, scoped, and time-limited session with its backend.
  4. This session then authorizes access to an Ed25519 signing key, managed by Para's MPC infrastructure.
  5. The transaction is ultimately signed with Ed25519, making it compatible with Solana, and then submitted to the network.

6. What Are the Security Trade-offs of Passkey Wallets?

Developers must rigorously evaluate the security implications.

Benefits of passkeys in Web3:

  • Elimination of seed phrase exposure: This addresses the single largest attack vector in crypto, where a vast majority of losses stem from phishing, blind signing, or stolen private keys.
  • Phishing resistance: Passkeys are cryptographically bound to the origin (Relying Party ID), making them impervious to most phishing attempts.
  • No server-side secrets: The server stores only the public key, mirroring the VaultKeepR model.
  • Secure Enclave isolation: Private keys reside in hardware, not vulnerable software memory.

Remaining considerations:

  • Device dependency: Passkeys are tied to specific devices. Cross-device synchronization (e.g., iCloud Keychain, Google Password Manager) introduces platform-specific trust assumptions.
  • MPC infrastructure trust: The MPC nodes responsible for managing the Ed25519 signing key become a critical trust anchor. Their security, audits, and decentralization are paramount. Recent vulnerabilities such as CVE-2026-26007: Subgroup Confinement Attack in pyca/cryptography highlight how even well-audited cryptographic libraries can harbor subtle but dangerous flaws in their curve implementations.
  • Recovery complexity: While superior to seed phrases, loss of all devices and passkeys still requires a robust recovery mechanism. Solutions like Shamir secret sharing or social recovery introduce their own complexities.

The analogy to VaultKeepR is apt: it uses fragmented recovery (Shamir 3-of-5) to distribute vault recovery fragments. The same principle applies to wallet keys: distribute shards across multiple passkeys, hardware keys, and social recovery contacts to mitigate single points of failure.

7. Why Are Web2 and Web3 Authentication Converging?

We are witnessing the convergence of password management and crypto wallet functionality.

The emergent unified model:

  • A single master key pair, generated and stored within your device's Secure Enclave, serves as the root of trust.
  • This key pair authorizes sessions for all digital interactions: website logins, password vault decryption, and crypto transaction signing.
  • The system operates without passwords, seed phrases, or reliance on a central server for key management.
  • Recovery mechanisms will shift towards cryptographic threshold schemes (Shamir, social recovery) rather than centralized "forgot password" functionalities.

VaultKeepR already embodies this model for credentials. Extending this architecture to Web3 means your password manager becomes your wallet.

SIMD-0075 is a pivotal technical milestone, enabling Solana to natively verify passkey signatures, a core requirement for native passkey wallet implementations. When combined with account abstraction (e.g., ERC-4337 on Ethereum, and SIMD-0075's implications on Solana), user onboarding to crypto can become as simple as:

Scan your face. You now have a wallet.

This future eliminates the need for written seed phrases and the associated risks, replacing them with biometrics and robust hardware-backed cryptography.

TL;DR for Developers

Concept What Changed
SIMD-0075 Solana now has a Secp256r1SigVerify precompile for on-chain verification of P-256 (WebAuthn) signatures.
Curve Mismatch WebAuthn uses P-256 (secp256r1), Solana uses Ed25519. Passkeys cannot directly sign Solana transactions due to cryptographic incompatibility.
Solution Utilize passkeys for session authorization (proving identity), then employ MPC-managed Ed25519 signers for transaction execution (producing Solana-compatible signatures).
VaultKeepR Parallel The architecture mirrors zero-knowledge password managers: on-device key derivation and secured storage, extended to decentralized backups.
For Your App Implement navigator.credentials.create() to establish a session, which then authorizes an MPC signer to generate Solana-compatible transaction signatures. No seed phrases are involved.
Security Win Private keys remain in secure hardware, never entering browser memory. The elimination of seed phrases removes a major attack vector and enhances phishing resistance.

The era of mnemonic seed phrases is drawing to a close. The Secure Enclave within every modern smartphone is poised to become the user's primary Solana passkey wallet. Our task as developers is to construct the bridging infrastructure.