Crabless Crab Cakes With Green Apple Guacamole
Ingredients
Directions
For the Cakes
2 c
corn kernels
Jump
0.25 c
onion, minced
Jump
0.25 c
green bell pepper, minced
Jump
0.25 c
mayonnaise
Jump
15 oz
canned whole hearts of palm or artichoke hearts, drained, diced, and lightly smashed
Jump
2 tsp
Old Bay seasoning
Jump
2 tbsp
chopped fresh flat-leaf parsley
Jump
2 tsp
Dijon mustard
Jump
0.33 c
gluten-free bread crumbs*
Or 1/2 cup almond meal
*Show Note
Jump
0
salt
Jump
0
pepper
Jump
For the Guacamole
3
avocadoes, cubed
Jump
2 lg
garlic cloves, minced
Jump
0
juice of 2 limes
Jump
0
salt
Jump
0
pepper
Jump
2
medium jalapeños, seeded and finely minced
Jump
1 sm
red onion, diced
Jump
2
vine tomatoes, seeded and diced
Jump
0.5 c
fresh cilantro, chopped
Jump
1 lg
green apple, spiralized with blade C
Jump
Additional Ingredients
2 tbsp
extra-virgin olive oil
Jump
Crabless Crab Cakes With Green Apple Guacamole

Yes, these crab cakes are crabless! It seems like an oxymoron, but once you make them, you’ll get it—and smell it. Thanks to Old Bay seasoning, Dijon mustard, and hearts of palm, these cakes are fit for a steak house. The proverbial cherry on top is definitely the green apple guacamole. Its tart sweetness ties all the flavors together, offering a refreshing balance to the potent Old Bay. A spiralizer creates the perfect apple noodle to give each forkful a crunch!

Tip: I prefer to make my own mayonnaise to ensure that the ingredients are wholesome. Or I’ll use a vegan brand, such as Sir Kensington’s. To make your own, in a food processor or by hand, blend together 1 egg yolk and 1 1/2 teaspoons fresh lemon juice. While whisking rapidly to emulsify, slowly stream in 1/2 cup avocado oil, 1 teaspoon at a time. Season with salt and pepper.

4-6 servings

  1. Make the cakes. Heat a large skillet over medium-high heat. When water flicked onto the skillet sizzles, add the corn, onion, and bell pepper and cook until tender, 3 to 5 minutes. Transfer 1 cup of the mixture to a food processor and pulse until coarse-smooth. Transfer to a medium bowl and add the mayonnaise, hearts of palm, Old Bay, parsley, mustard, and 1⁄4 cup of the bread crumbs. Season with salt and pepper and stir well to combine.
  2. Line a baking sheet with parchment paper. Using your hands, form the mixture into 12 cakes, 2 inches in diameter, and transfer to the prepared baking sheet. Refrigerate for 10 to 15 minutes to bind.
  3. Make the guacamole. Place all the guacamole ingredients in a medium bowl and stir together until combined but some chunks of avocado still remain. Taste and adjust the seasoning to your preferences, adding more salt, cilantro, lime, or jalapeño as needed. Refrigerate until ready to serve.
  4. Heat 1 tablespoon of the olive oil in a large skillet over medium-high heat. When the oil is shimmering, add six cakes and cook for about 2 minutes per side or until golden brown. Transfer to a platter. Wipe down the skillet, add another 1 tablespoon of the olive oil, and cook the remaining cakes.
  5. Serve two or three cakes and about 1/2 cup of guacamole on each plate.

Excerpted from “Inspiralize Everything: An Apples-to-Zucchini Encyclopedia of Spiralizing” by Ali Maffucci, copyright © 2016, published by Clarkson Potter, an imprint of Penguin Random House LLC. Photography copyright © 2016 by Evan Sung.

Inspiralize Everything

Inspiralize Everything

Book Cover
[email_signup id="3"]
<div class="email-subscribe exp-subscribe subscribe"> <div class="alert alert-success exp-success ga-etembed-success" style="display:none;"> Great! You've signed up successfully! </div> <div class="alert alert-danger exp-error" style="display:none;"> We are experiencing an error, please try again. </div> <form name="subscribe" id="email-signup" class="email-signup-form" action="https://www.tastecooking.com/wp-admin/admin-ajax.php" method="POST" target="_top" data-event-assigned="false"> <fieldset class="form-group form-inline email-submit-group"> <label for="email-address" class="sr-only">Email Address</label> <input id="email-newsletter" type="email" placeholder="your@email.com" class="email-newsletter text email form-control" name="email" value=""> <button type="submit" value="Subscribe" name="subscribe" class="btn btn-primary email-submit-btn ga-etembed-success"> <i class="fa fa-envelope"></i> Subscribe </button> </fieldset> <small class="exp-small terms" style=""> By clicking Subscribe, I acknowledge that I have read and agree to the Penguin Random House <a href="http://www.penguinrandomhouse.com/privacy/" target="_blank">Privacy Policy</a> and <a href="http://www.penguinrandomhouse.com/terms/" target="_blank">Terms of Use</a> and agree to receive news and updates from TASTE and Penguin Random House. </small> <fieldset class="field-group checkboxes" style="display:none"> <div class="checkbox"> <label> <input type="checkbox" name="programs[]" value="505,50501,1" class="exp-checkbox" checked="checked"> <span><strong>Tastebook General</strong></span> </label> </div> <div class="checkbox"> <label> <input type="checkbox" name="programs[]" value="505,50502,1" class="exp-checkbox" checked="checked"> <span><strong>Tastebook Promo</strong></span> </label> </div> </fieldset><!-- /.checkboxes --> <input type="hidden" name="data_acq_code" value="TASTE_POPUP_STATIC_ONGOING" /> <input type="hidden" name="data_programs" value="50501|505,50502|505" /> <input type="hidden" name="form_id" value="3" /> <input type="hidden" name="partner" value="" /> <input type="hidden" name="action" value="crown_email_signup_submit" /> <input type="hidden" name="ref_url" value="" /> </form> </div> <script> jQuery(document).ready(function () { var unassigned_forms; setInterval( function() { //Check for unassigned forms var forms = jQuery( '.email-signup-form' ); unassigned_forms = false; forms.each( function( index ) { if ( jQuery( this ).attr( 'data-event-assigned' ) === 'false' ) { unassigned_forms = true; } }); if ( unassigned_forms ) { forms.off( 'submit' ).on( 'submit', function ( e ) { forms.attr( 'data-event-assigned', 'true' ); e.preventDefault(); // Basic email validation var email = jQuery(e.target).find('.email-newsletter').val(), valid_email = false, groupEl = jQuery(e.target).closest('.email-subscribe'); if ( !!email && typeof(email) === "string" ) { var email_array = email.split('@'); if ( email_array.length === 2 ) { if ( email_array[1].split('.').length > 1 ) { valid_email = true; } } } if ( valid_email ) { jQuery('.alert-danger').hide(); // Show loading gif groupEl.find('.email-signup-form').hide(); groupEl.find('.email-submit-loading').show(); // Populate ref_url jQuery(this).find('input[name="ref_url"]').val(window.location.href); // Generate Payload var payload = jQuery(this).serializeArray(); jQuery.ajax({ url: jQuery(this).attr('action'), type: 'POST', data: payload, success: function (data) { // Hide loading spinner groupEl.find('.email-signup-form').show(); groupEl.find('.email-submit-loading').hide(); // Display success msg var target = jQuery(e.target); jQuery(e.target).hide(); jQuery(e.target).parent().find('.alert-success').show(); jQuery(e.target).parent().find('#downloadbtn').show(); }, fail: function (err) { // Hide loading spinner groupEl.find('.email-signup-form').show(); groupEl.find('.email-submit-loading').hide(); // Display failure msg var target = jQuery(e.target); jQuery(e.target).hide(); jQuery(e.target).parent().find('.alert-danger').show(); } }); } else { groupEl.find('.alert-danger').html('Please enter a valid email address.').show(); } }); forms.off( 'keypress' ).on( 'keypress', function ( e ) { if ( e.which === 13 ) { e.preventDefault(); jQuery( this ).submit(); } }); } }, 100); }); </script>
[email_signup id="3"]
<div class="email-subscribe exp-subscribe subscribe"> <div class="alert alert-success exp-success ga-etembed-success" style="display:none;"> Great! You've signed up successfully! </div> <div class="alert alert-danger exp-error" style="display:none;"> We are experiencing an error, please try again. </div> <form name="subscribe" id="email-signup" class="email-signup-form" action="https://www.tastecooking.com/wp-admin/admin-ajax.php" method="POST" target="_top" data-event-assigned="false"> <fieldset class="form-group form-inline email-submit-group"> <label for="email-address" class="sr-only">Email Address</label> <input id="email-newsletter" type="email" placeholder="your@email.com" class="email-newsletter text email form-control" name="email" value=""> <button type="submit" value="Subscribe" name="subscribe" class="btn btn-primary email-submit-btn ga-etembed-success"> <i class="fa fa-envelope"></i> Subscribe </button> </fieldset> <small class="exp-small terms" style=""> By clicking Subscribe, I acknowledge that I have read and agree to the Penguin Random House <a href="http://www.penguinrandomhouse.com/privacy/" target="_blank">Privacy Policy</a> and <a href="http://www.penguinrandomhouse.com/terms/" target="_blank">Terms of Use</a> and agree to receive news and updates from TASTE and Penguin Random House. </small> <fieldset class="field-group checkboxes" style="display:none"> <div class="checkbox"> <label> <input type="checkbox" name="programs[]" value="505,50501,1" class="exp-checkbox" checked="checked"> <span><strong>Tastebook General</strong></span> </label> </div> <div class="checkbox"> <label> <input type="checkbox" name="programs[]" value="505,50502,1" class="exp-checkbox" checked="checked"> <span><strong>Tastebook Promo</strong></span> </label> </div> </fieldset><!-- /.checkboxes --> <input type="hidden" name="data_acq_code" value="TASTE_POPUP_STATIC_ONGOING" /> <input type="hidden" name="data_programs" value="50501|505,50502|505" /> <input type="hidden" name="form_id" value="3" /> <input type="hidden" name="partner" value="" /> <input type="hidden" name="action" value="crown_email_signup_submit" /> <input type="hidden" name="ref_url" value="" /> </form> </div> <script> jQuery(document).ready(function () { var unassigned_forms; setInterval( function() { //Check for unassigned forms var forms = jQuery( '.email-signup-form' ); unassigned_forms = false; forms.each( function( index ) { if ( jQuery( this ).attr( 'data-event-assigned' ) === 'false' ) { unassigned_forms = true; } }); if ( unassigned_forms ) { forms.off( 'submit' ).on( 'submit', function ( e ) { forms.attr( 'data-event-assigned', 'true' ); e.preventDefault(); // Basic email validation var email = jQuery(e.target).find('.email-newsletter').val(), valid_email = false, groupEl = jQuery(e.target).closest('.email-subscribe'); if ( !!email && typeof(email) === "string" ) { var email_array = email.split('@'); if ( email_array.length === 2 ) { if ( email_array[1].split('.').length > 1 ) { valid_email = true; } } } if ( valid_email ) { jQuery('.alert-danger').hide(); // Show loading gif groupEl.find('.email-signup-form').hide(); groupEl.find('.email-submit-loading').show(); // Populate ref_url jQuery(this).find('input[name="ref_url"]').val(window.location.href); // Generate Payload var payload = jQuery(this).serializeArray(); jQuery.ajax({ url: jQuery(this).attr('action'), type: 'POST', data: payload, success: function (data) { // Hide loading spinner groupEl.find('.email-signup-form').show(); groupEl.find('.email-submit-loading').hide(); // Display success msg var target = jQuery(e.target); jQuery(e.target).hide(); jQuery(e.target).parent().find('.alert-success').show(); jQuery(e.target).parent().find('#downloadbtn').show(); }, fail: function (err) { // Hide loading spinner groupEl.find('.email-signup-form').show(); groupEl.find('.email-submit-loading').hide(); // Display failure msg var target = jQuery(e.target); jQuery(e.target).hide(); jQuery(e.target).parent().find('.alert-danger').show(); } }); } else { groupEl.find('.alert-danger').html('Please enter a valid email address.').show(); } }); forms.off( 'keypress' ).on( 'keypress', function ( e ) { if ( e.which === 13 ) { e.preventDefault(); jQuery( this ).submit(); } }); } }, 100); }); </script>